WO2018022109A1 - Workflow-authorizing computing device authentication - Google Patents

Workflow-authorizing computing device authentication Download PDF

Info

Publication number
WO2018022109A1
WO2018022109A1 PCT/US2016/044868 US2016044868W WO2018022109A1 WO 2018022109 A1 WO2018022109 A1 WO 2018022109A1 US 2016044868 W US2016044868 W US 2016044868W WO 2018022109 A1 WO2018022109 A1 WO 2018022109A1
Authority
WO
WIPO (PCT)
Prior art keywords
computing device
workflow
authentication
variable data
user
Prior art date
Application number
PCT/US2016/044868
Other languages
French (fr)
Inventor
Steven J. Simske
Jason S. Aronoff
Matthew D. Gaubatz
Original Assignee
Hewlett-Packard Development Company, L.P.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Hewlett-Packard Development Company, L.P. filed Critical Hewlett-Packard Development Company, L.P.
Priority to PCT/US2016/044868 priority Critical patent/WO2018022109A1/en
Priority to CN201680085232.9A priority patent/CN109416780A/en
Priority to EP16910767.9A priority patent/EP3446266A4/en
Priority to US16/097,950 priority patent/US11030630B2/en
Publication of WO2018022109A1 publication Critical patent/WO2018022109A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/018Certifying business or products
    • G06Q30/0185Product, service or business identity fraud
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K19/00Record carriers for use with machines and with at least a part designed to carry digital markings
    • G06K19/06Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
    • G06K19/06009Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
    • G06K19/06037Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking multi-dimensional coding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/1408Methods for optical code recognition the method being specifically adapted for the type of code
    • G06K7/14172D bar codes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/08Logistics, e.g. warehousing, loading or distribution; Inventory or stock management
    • G06Q10/087Inventory or stock management, e.g. order filling, procurement or balancing against orders
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/06Buying, selling or leasing transactions
    • G06Q30/0601Electronic shopping [e-shopping]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/083Network architectures or network communication protocols for network security for authentication of entities using passwords
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/0861Network architectures or network communication protocols for network security for authentication of entities using biometrical features, e.g. fingerprint, retina-scan
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • H04L63/0876Network architectures or network communication protocols for network security for authentication of entities based on the identity of the terminal or configuration, e.g. MAC address, hardware or software configuration or device fingerprint
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces

Definitions

  • VDCs are machine-readable components that contain embedded information.
  • the embedded information upon extraction, can perform any number of functions or trigger any number of workflows.
  • a scanning device of a mobile device can capture a printed variable data component.
  • a processor of the mobile device can then extract the embedded information; which information could direct a web browser of the mobile device to a particular website.
  • Such variable data components can also be used in the detection of counterfeit products.
  • the VDCs can also be used to drive the stages of other multi-stage interactions.
  • FIG. 1 is a diagram of an environment for authorizing workflows following computing device authentication, according to an example of the principles described herein.
  • FIG. 2 is a flowchart illustrating a method for authorizing workflows following computing device authentication, according to an example of the principles described herein.
  • Fig. 3 is a diagram of a computing device that authorizes workflows following computing device authentication, according to an example of the principles described herein.
  • Fig. 4 illustrates a user interface to initialize capturing a variable data component, according to an example of the principles described herein.
  • Fig. 5 illustrates a user interface to prompt authentication of the computing device, according to an example of the principles described herein.
  • FIG. 6 is a flowchart illustrating a method for authorizing workflows following computing device authentication, according to an example of the principles described herein.
  • FIG. 7 is a diagram of a computing system for authorizing workflows following computing device authentication, according to another example of the principles described herein.
  • VDCs Variable data component(s)
  • the encoded information once extracted, can be used to perform any number of functions.
  • encoded information in a VDC can be used to trigger subsequent workflows.
  • a user may scan a QR code located at a bus stop with an image scanning tool (e.g., camera) of a mobile device, information encoded in the QR code could direct the web browser of the mobile device to a web page that displays bus route information for busses passing that stop.
  • image scanning tool e.g., camera
  • VDCs can also be used to assist in the detection of counterfeit products.
  • a printed VDC could be placed on a product package.
  • a scanner of a mobile device can capture the VDC.
  • a processor of the mobile device then parses the VDC to retrieve the embedded information, in some examples, the embedded information includes an electronic security image that is returned to the mobile device. If the electronic security image matches a security image printed on the product package, a user may have some measure of confidence that the product is authentic. Otherwise, the user may not wish to proceed further with any downstream workflow. That is, if the printed security image does not match the transmitted security image, a user can acknowledge that the associated product may be counterfeit. While specific workflows are described herein, specifically as they relate to product authentication, the VDC as described herein may be used to trigger any number of downstream workflows.
  • VDCs are useful in executing subsequent workflows and to some degree defecting counterfeit products
  • some characteristics of the environment in which the VDCs are used limit adoption of these techniques to specific types of workflows.
  • any workflow triggered by the scanning of a VDC is generic, and not user-specific.
  • any computing device, or any user who scans a QR code at a bus stop will receive the same information, regardless of the identity of the user. Accordingly, fully customizable role-based workflows that are generated and executed based on device-specific information are not possible.
  • VDCs as used to authenticate products can be data- mined.
  • a data-mining bot i.e., a computing application that runs automated scripts, can attempt to replicate a security image.
  • an insidious third party can then print the replicated security image and fraudulently place that security image on a counterfeit product.
  • the bot could scan a barcode or generate permutations of numerical combinations represented by a barcode, and then poll the networked computing device for all variations of an associated security mark, which security mark could be a guiiloche or other graphical alphanumeric (that is, set of symbols representing specific codes or strings), in other words, the security mark may be any type of mark in which a large plurality of different symbols and/or symbol sets can be rendered. A counterfeiter could then place the guiiloche on their own product, thus confusing consumers as to the authenticity of a particular product.
  • the present specification describes a computing device authentication operation that 1 ) improves the security of the downstream workflows and 2) provides customizable workflows that are enabled via information gathered regarding the computing device during an authentication operation.
  • Such customizable workflows allow for tailored workflows based on user-specific or device-specific information.
  • This customized workflow enablement is carried out after a computing device is authenticated. During such an authentication process, information about the computing device, which computing device may be tied to a particular user, is acquired. This information can be used to select, define, or interactively select among options to direct a downstream workflow.
  • Such authentication includes user interaction such that the downstream workflows are just accessible after the device is authenticated, in an example, subsequent workflow stages are determined based on which authenticated users/devices are authorized to continue with stages associated with various roles. Put another way, depending on the role authorized to proceed based on given authentication information (which could include validated or inauthentic identifiers/credentials), the content available via the subsequent stages of the workflow can be limited appropriately.
  • the present specification describes a method.
  • a computing device acquires data encoded in a VDC.
  • the computing device then authenticates the computing device and/or a proper user of the computing device.
  • a proper user is a user that is authenticated using
  • the present specification also describes a computing device.
  • the computing device includes an acquire engine to acquire data encoded in a VDC.
  • An authentication engine of the computing device authenticates the computing device and/or a proper use of the computing device.
  • a workflow engine of the computing device authorizes a downstream workflow.
  • the downstream workflow is 1 ) defined by data encoded in the VDC and information acquired during authentication of the computing device and/or a proper user of the computing device and 2) enabled via the authentication of the computing device and/or the proper user of the computing device.
  • the computing device also includes a user interface to receive user input information referenced during authentication.
  • the present specification describes a computing system that includes a processor and a machine-readable storage medium coupled to the processor.
  • An instruction set is stored in the machine-readable storage medium and is to be executed by the processor.
  • the instruction set includes instructions to capture an image of a printed VDC and upon capturing the image of the printed VDC, authenticate the computing device and/or a proper user of the computing device.
  • the instruction set also includes instructions to, upon authentication of the computing device and/or proper user of the computing device, authorize a downstream workflow.
  • the downstream workflow is defined by data encoded in the printed VDC and enabled via the authentication of the computing device and/or proper user of the computing device.
  • the instruction set also includes instructions to, upon authorizing the downstream workflow, prompt a user to capture another one of a group of printed VDCs.
  • a subset of the group of VDCs triggers a subsequent workflow and the number of printed VDCs that each trigger a subsequent workflow is fewer than or equal to the number of printed VDCs in the group, [0020]
  • Using such a method and system 1 ties access to subsequent workflows to computing device authentication; 2) enhances security of authentication information; 3) provides for fully customizable workflows based on the automated or manual identification of the computing device; 4) provides role-based access control workflows; 5) allows for definition of workflows before or in real-time based on information acquired about the computing device; 6) facilitates adaptive workflows while using the same variable data components; 7) facilitates the identification of fraudulent users; and 8) dissuades data-mining by insidious third parties.
  • the devices disclosed herein may provide utility in addressing other matters and deficiencies in a number of technical areas. Therefore, the systems and methods
  • workflow refers to a defined series of computer-based tasks to produce a final outcome.
  • Each stage in a series that makes up the workflow generally has inputs and produces outputs (including simply "states") that transforms data.
  • a role-based workflow refers to a workflow with a plurality of sequences whose number and order can be specified beforehand and associated with a given role for a given user, user type, or agent.
  • variable data component refers to a component that can be interrogated (i.e. , scanned, decoded, etc.) by a computing device and that stores encoded information.
  • the variable data component may be printed, such as a barcode, or affixed to a surface such as an RF!D chip.
  • the variable data component may be physical as in the example of a printed or affixed variable data component, or it may be virtual, as in an image on a computer screen.
  • authentication information refers to information utilized during authentication of a computing device and/or proper user of the computing device, and any subsequent determinations of workflow stages.
  • the authentication could include information relating to an owner of the computing device or a unique identifier of the computing device, among others.
  • the term "proper user” refers to a user that is paired with the computing device, sometimes uniquely, for example via biometric association of the user with the computing device.
  • the term "a number of” or similar language is meant to be understood broadly as any positive number including 1 to infinity; zero not being a number, but the absence of a number.
  • Fig, 1 is a diagram of an environment (100) for authorizing workflows following computing device (102) authentication, according to an example of the principles described herein.
  • VDCs variable data components
  • a VDC (104) can be any image, symbol, or other component that includes or references encoded information.
  • Such VDCs (104) may be printable such as a guilioche or other graphical alphanumeric, 2D matrix, barcode, QR code or any visual mark that is suitable for printing, in some examples, the VDC (104) is not printable but is a physical component that could be affixed to a surface.
  • FIG. 1 depicts a VDC (104) printed on a substrate, the VDC (104) may also be an electronic component, such as an image displayed on an electronic screen.
  • a user employs a computing device (102) having a capture device such as a scanner or a camera. Using this capture device, the user acquires data encoded by the VDC (104). Specifically, as depicted in Fig. 1 , a camera or scanner can capture a digital image of a printed VDC (104).
  • the VDC (104) is an RFID chip
  • the user computing device (102) may include an RFID reader that can read variable bit streams
  • the VDC may be a small on-chip memory
  • the capture device could be an embedded memory reader to read the small on-chip memory.
  • Fig, 1 depicts a mobile phone as the computing device (102), any type of computing device (102) may be
  • computing devices (102) include a personal computing device, a notebook, laptop computer, a tablet, a gaming system, or other computing device (102) that has the capability of capturing a VDC (104) and processing data encoded therein.
  • the VDC (104) may include encoded information that is interpreted by the computing device (102).
  • the VDC (104) may include information that at least in part identifies subsequent workflows that may be executed. This information, when used in conjunction with data gathered about the computing device (102) during authentication, authorizes role-specific workflows that may be a subset of workflows identified by data encoded in the VDC (104).
  • the VDC (104) may also include information that triggers an authentication engine (106) of the computing device (102).
  • the authentication engine (106) is indicated as a dashed-box indicating its location internal to the computing device (102).
  • the authentication engine (106) uses authentication information relating to the computing device (102) or a user associated with the computing device (102) to authenticate the computing device (102) and accordingly authorize subsequent user-specific workflows.
  • the authentication engine (106) facilitates
  • a computing device (102) may be sufficient.
  • an identifier of the computing device (102) may be sufficient to authenticate.
  • knowledge of the device or a user of the device i.e., a username and password, may be used to authenticate.
  • an identity of a user may be verified, for example via biometric information gathered about the user.
  • the authentication engine (106) can be used in part to acquire these components as well as identify which level of authentication is to be used for a particular workflow/role.
  • the authentication engine (106) may provide some authentication information, which may include, be derived from, or tied to, some representation of an identifier, or some form of credentials, either directly describing the device such as a media access control (MAC) address, or a UDID number, or associated with the device.
  • some authentication information may include, be derived from, or tied to, some representation of an identifier, or some form of credentials, either directly describing the device such as a media access control (MAC) address, or a UDID number, or associated with the device.
  • MAC media access control
  • the authentication engine (106) can either manually or automatically obtain authentication information from the computing device (102) and uses such authentication information to verify that the associated computing device (102) is permitted to access subsequent workflows, in some examples, authentication information obtained during the authentication process may include personal information about a user of the computing device (102). This personal information could be used to select and/or define the workflow that is authorized.
  • the operation to enter information related to the computing device (102), i.e., adding a role- specific identification allows for the discernment of counterfeiting.
  • the increased ability to discern a counterfeit operation may dissuade data-mining, i.e., collecting the data associated with activating a workflow that the data-miner has no role-based right to act upon, as it would be less effective.
  • Fig. 2 is a flowchart illustrating a method (200) for authorizing workflows following computing device (Fig. 1 , 102) authentication, according to an example of the principles described herein.
  • the methods (200, 600) may be described below as being executed or performed by at least one device, for example, the computing device (Fig. 1 , 102). Other suitable systems and/or computing devices may be used as well.
  • the methods (200, 600) may be implemented in the form of executable instructions stored on at least one machine-readable storage medium of at least one of the devices and executed by at least one processor of at least one of the devices.
  • the machine-readable storage medium may include a standalone program installed on the device.
  • the machine-readable medium may include instructions delivered by a browser on the device.
  • the methods (200, 600) may be implemented in the form of electronic circuitry (e.g., hardware). While Figs. 2 and 6 depict operations occurring in a particular order, a number of the operations of the methods (200, 600) may be executed concurrently or in a different order than shown in Figs. 2 and 6. In some examples, the methods (200, 600) may include more or fewer operations than are shown in Figs. 2 and 6. in some examples, a number of the operations of the methods (200, 600) may, at certain times, be ongoing and/or may repeat.
  • a computing device may include a camera, scanner, or other capturing device to capture a digital image of a printed VDC (Fig. 1 , 104). While specific reference is made to capturing an image of a printed VDC (Fig. 1 , 104), any method of interrogating a VDC (Fig. 1 , 104) that stores encoded data may be implemented. For example, if a non-printed VDC (Fig. 1 , 104), for example an RFiD chip is used, the computing device (Fig.
  • the VDC (Fig. 1 , 104) refers to any image, symbol, or component that includes encoded data, or that references encoded data that can be interrogated by a computing device (Fig. 1 , 102) such as a mobile computing device.
  • the data associated with may include various pieces of information.
  • the VDC (Fig. 1 , 104) may include data regarding subsequent workflows and a command to authenticate the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig. 1 , 102).
  • the data acquired from the captured image can in part identify the different workflows.
  • information about the computing device (Fig. 1 , 102) is received during authentication.
  • a role-specific workflow as defined by the data associated with the VDC (Fig. 1 , 104) can be selected.
  • the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig. 1 , 102) is then authenticated (block 202).
  • the authentication (block 202) is performed using the computing device (Fig. 1 , 102) which utilizes various mechanisms in authenticating the computing device (Fig. 1 , 102).
  • computing devices (Fig. 1 , 102) may include various applications that either manually or automatically identify the computing device (Fig. 1 , 102).
  • authentication of the computing device (Fig. 1 , 102) is extended by authentication of the user or operator of the computing device (Fig. 1 , 102). For example, a user may be paired with a particular computing device (Fig. 1 , 102).
  • a smartphone may include a biometrics reader that is initially set up to recognize a particular user's fingerprint. This information can be stored locally on the computing device (Fig. 1 , 102) so that a swipe with a finger of the particular user unlocks the computing device, even if a user is not able to access a carrier.
  • a user that is paired with a particular computing device (Fig. 1 , 102) may be referred to as a "proper user" or "authorized user” of the computing device (Fig. 1 , 102).
  • a proper user is a user that has access to the computing device (Fig. 1 , 102) based on biometric information, which biomefric information may be stored on the computing device (Fig. 1 , 102).
  • While some computing devices such as mobile phones, may allow one person to unlock the computing device (Fig. 1 , 102), other computing devices such as laptop computers can be set up to read the biometric information of any number of users. Once the appropriate level of authentication has been achieved, the user is then authorized to perform the associated workflows. That is, role-based access is then enabled.
  • the computing device can be authenticated by authentication of the user of the computing device (Fig. 1 , 102). Accordingly, in some cases, information related to the user of the computing device (Fig. 1 , 102) can authenticate the computing device (Fig. 1 , 102). Specific non-limiting examples of authentication of an operator of a computing device (Fig, 1 , 102) serving to authenticate the computing device (Fig. 1 , 102) are provided below.
  • a password-protected computing device (Fig. 1 , 102) can be authenticated via entry of a username/password. If an incorrect username/password is entered, then the computing device (Fig. 1 , 102) cannot be authenticated, in a related example, login information for a particular social network service can also be used to authenticate the computing device (Fig. 1 , 102). As another example, biometric login information could be used to authenticate the computing device (Fig. 1 , 102).
  • a computing device (Fig. 1 , 102) may include applications to acquire biometrics of the user. Examples of such applications include a fingerprint reader, a voice recognition application, and a facial recognition application among others. Accordingly, biometric information could be used to authenticate the computing device (Fig, 1 , 102).
  • the computing device may be assigned a unique identifier such as an international mobile equipment identify (IMEI) number, an international mobile subscriber identity (IMSI) number, a mobile equipment identifier (MEID), serial number, media access control (MAC) number, and electronic serial number (ESN), or other unique identifier of the computing device (Fig. 1 , 102).
  • IMEI international mobile equipment identify
  • IMSI international mobile subscriber identity
  • MEID mobile equipment identifier
  • serial number a mobile equipment identifier
  • MAC media access control
  • ESN electronic serial number
  • a global-positioning signal (GPS) application could acquire information regarding the geographical positioning of the computing device (Fig. 1 , 102). If the GPS information indicates that the computing device (Fig. 1 , 102) is in an expected or valid position, the computing device (Fig. 1 , 102) can be
  • the authentication information may be purchase device authorization data. For example, it is possible to draw a link between a mechanism for purchasing products/services, i.e., a credit card, and the computing device (Fig. 1 , 102). If the purchasing mechanism data, i.e., credit card information, stored in the computing device (Fig. 1 , 102) is valid, the computing device (Fig. 1 , 102) can be authenticated, in still yet another example of authenticating a computing device (Fig.1 , 102), the payment authorization information may be entered by a user during authentication, or by swiping a payment card through a reader attached to the computing device (Fig. 1 , 102). While specific examples have been provided of different authentication information, other authentication information could also be used.
  • the authentication information can be manually retrieved or automatically retrieved.
  • a user may be prompted to enter username/password, social networking login information, GPS location, and/or purchase mechanism information during authentication.
  • username/password a user may be prompted to enter username/password, social networking login information, GPS location, and/or purchase mechanism information during authentication.
  • such information may be cached, or in the cases of device identifiers, may be stored in system storage and can be obtained independent of user entry of such information. In this case, a user may provide authorization for acquisition and use of such authentication information.
  • Authentication (block 202) of the computing device may include comparison of the acquired authentication information against a database.
  • the computing device may include a database of valid authentication information.
  • biometric authentication it may be possible to verify a user via mechanisms local to a given device, but still prevent said user from accessing certain content if their authentication information is not found in the database.
  • authentication (block 202) may include hashing of the acquired authentication information. For example, a username/password may be hashed and associated with a trusted platform module/chip on the computing device (Fig. 1 , 102).
  • authentication may be achieved by comparing collected authentication information with various instances of authentication information associated with different roles, and selecting the best match.
  • such authentication occurs on the computing device (Fig. 1 , 102) that was used to acquire the data associated with the VDC (Fig. 1 , 104).
  • the subsequent workflows that are executed, because they are based on computing device and/or device-mediated (Fig. 1 , 102) authentication can be specific to the computing device (Fig, 1 , 102) and the computing device (Fig, 1 , 102) relationship to the owner. Accordingly, such authentication occurs through engines on, associated with, or used by, the computing device (Fig. 1 , 102).
  • the computing device can then authorize (block 203) a downstream workflow based on information received via acquisition of data associated with the VDC (Fig, 1 , 104) as well as the authentication information of the computing device (Fig, 1 , 102) and/or proper user of the computing device (Fig. 1 , 102).
  • the workflow that is executed is defined, at least in part, by the VDC (Fig. 1 , 104), and is enabled via the authentication of the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig. 1 , 102).
  • the VDC Fig. 1 , 104 either includes encoded information relating to the subsequent workflows or references a location where the subsequent workflows are stored, but it is due to the authentication of a computing device (Fig. 1 , 102) that a particular workflow is executed.
  • downstream workflows may be defined by
  • a computing device can be authenticated by obtaining information, such as
  • This information may include information regarding the operation of the computing device (Fig. 1 , 102), position within an organization of the user, demographic information of the user, and personal preferences. Such information can lead to a determination of a user's role and can be used to select or generate the desired workflow. Accordingly, based on information included or referenced by the VDC (Fig. 1 , 104) and the role of the currently authenticated computing device (Fig. 1 , 102), role-based workflows are implemented. In other words, a mapping is generated between the workflow data associated with the VDC (Fig. 1 , 104), data relating to the computing device (Fig.
  • the workflow is defined by both the VDC (Fig. 1 , 104) and the authentication information of the computing device (Fig. 1 , 102),
  • an authenticated user may for instance, receive read access to some resources upon most validations of their identity, but may receive write access if biometric validation is provided.
  • fully customizable workflows that are secure from insidious third parties can be implemented, [0051]
  • the downstream workflows that are authorized may take many forms.
  • the downstream workflow could include the sending of a security-confidence mark that, when compared to a printed security-confidence mark, provides a user with confidence that subsequent workflows are valid.
  • the security-confidence mark may be distinct from the VDC (Fig. 1 , 104) described earlier, in the specific case of
  • a security image may be electronically transmitted to the computing device (Fig. 1 , 102).
  • a user may then compare the electronically transmitted security image against a printed security image to ensure that they match. If they match, a user can have confidence that the associated product is authentic. If they do not match, a user can be tipped-off that a counterfeit or otherwise illicit action may have occurred.
  • the downstream workflow includes the transmission of information specific to a user of the computing device (Fig. 1 , 102). For example, during authentication of the computing device (Fig. 1 , 102), certain information relating to the user of the computing device (Fig. 1 , 102) may have been obtained. This authentication information could be used to authorize a workflow that provides user-specific information.
  • a user may capture a VDC (Fig. 1 , 104) disposed on a food container, if a social network login is used to authenticate the computing device (Fig. 1 , 102), the additional workflow may include posting targeted advertisements on that user's social media page. While specific reference is made to advertising specific to the user, other types of information specific to the user may be provided based on the information acquired during authentication. Such information includes allergy information specific to the user, ingredient information, caloric information which could be transmitted to the user's dietary intake application, etc.
  • notifications of the user's action can be passed to a social networking application related to the corresponding
  • the downstream workflow includes a command to trigger execution of an application to read hidden data within the VDC (Fig. 1 , 104).
  • some applications can read obfuscated information in a VDC (Fig, 1 , 104) which is unreadable by some scanners scanner.
  • Such information includes color patterns, steganographic marks, or the like.
  • the downstream workflow includes a prompt to capture another one of a group of secondary VDCs.
  • the substrate on which the initial VDC (Fig. 1 , 104) is included may include other secondary VDCs. A subset of these secondary VDCs may trigger subsequent workflows. Accordingly, the prompt may indicate to a user which of the secondary VDCs triggers a workflow and which do not.
  • each of the subset of secondary VDCs may trigger a different workflow, or different stages of a larger workflow.
  • one secondary VDC could be used to deliver customer loyalty points to a consumer
  • another secondary VDC could deliver a coupon
  • another secondary VDC could collect a donation contribution
  • another secondary VDC could facilitate a social media purpose such as posting information to a social networking site.
  • a user interface of the computing device (Fig. 1 , 102) may include an identification of secondary VDCs that trigger subsequent workflows, and what subsequent workflows are triggered.
  • Requiring authentication prior to executing workflows based on secondary VDCs reduces the efficacy of data-mining.
  • the number of secondary VDCs in the group that trigger subsequent workflows may be fewer than or equal to the number of secondary VDCs in the group.
  • reserve data marks reduce the likelihood of data-mining as a bot cannot collect all of the salient information automatically by polling a service with a large number of VDC values that are not used.
  • FIG. 3 is a diagram of a computing device (102) for authorizing workflows following computing device (102) authentication, according to an example of the principles described herein.
  • the computing device (102) includes various hardware components.
  • the computing device (102) includes a number of engines.
  • the engines refer to a combination of hardware and program instructions to perform a designated function.
  • the engines may be hardware.
  • the engines may be implemented in the form of electronic circuitry (e.g. , hardware).
  • Each of the engines may include its own processor, but one processor may be used by ail the modules.
  • each of the engines may include a processor and memory. Alternatively, one processor may execute the designated function of each of the modules.
  • the engines may be distributed across hardware and machine-readable storage mediums of a variety of devices.
  • the acquire engine (308) acquires data encoded in the variable data component (Fig. 1 , 104).
  • the VDC (Fig. 1 , 104) may include encoded data that includes instructions regarding the execution of workflows and/or instructions directing an authentication engine (106) to authenticate the computing device (102).
  • the acquire engine (308) may include components to decode the encoded information.
  • the acquire engine (308) may include a scanner, camera or other capture device that captures a digital image of a printed variable data component (Fig. 1 , 104).
  • the VDC (Fig. 1 , 104) is a RFID chip
  • the acquire engine (308) includes an RF reader that can acquire the RF!D and any associated information.
  • the data acquired by the acquire engine (308) may trigger an authentication engine (108) to authenticate the computing device (102).
  • the authentication engine (106) relies on various types of authentication information, which may pertain to a user or operator of the computing device (102) to authenticate the computing device (102). Using such information, the authentication engine (106) can verify, via a number of methods, the computing device (102). This authentication may include finding an exact match for an identifier of the computing device (102) or performing a statistical analysis of biometric information relating to an operator of the computing device (102). Authentication may also include otherwise processing the information, i.e., hashing a username/password, to determine whether the hashed data string matches a valid hashed data string.
  • the computing device (102) is authenticated by the user having an identity and possession of the computing device (102). That is, the computing device (102) is authenticated based on information associated with the owner/possessor of the computing device (102). In some examples, the computing device (102) is authenticated by the user having an identity and possession of the computing device (102). That is, the computing device (102) is authenticated based on information associated with the owner/possessor of the computing device (102). In some
  • a processor of the computing device (102) may execute instructions stored on the computing device (102) that either compare the authentication information against a database or otherwise process the authentication information using a trusted module in order to authentication the computing device (102).
  • the computing device (102) also includes a workflow engine (310) that authorizes a downstream workflow.
  • the downstream workflow is 1 ) defined by at least data encoded, or otherwise referenced, in the VDC (Fig. 1 , 104) as well as information acquired during authentication of the computing device (102) and 2) enabled via the authentication of the computing device (102).
  • the authorized workflow may be user or role-specific to the owner of the computing device (102).
  • the workflow engine (310) receives the workflow that is to be executed after generation of the associated VDC (Fig. 1 , 104).
  • a VDC (Fig. 1 , 104) could be generated that includes a URL that includes the commands associated with carrying out a workflow. These commands may be generated after the VDC (Fig.
  • a VDC (Fig. 1 , 104) could be printed and affixed to a product package.
  • the initial workflow associated with the VDC may present product information such as links to drivers, advertising material, etc. If at a point after generation of the VDC (Fig. 1 , 104) product information changes, i.e., a recall or a particular advertising campaign ends, the workflow operations as identified in the URL may be changed, while retaining the previous mapping between the URL and the then existing VDC (Fig. 1 , 104). Doing so is beneficial in that it allows for customizable, and updatable workflows, all while being associated with a single VDC (Fig. 1 , 104) that has already been printed, and therefore does not justify a re-printing following the update to the associated workflow.
  • the computing device (102) also includes a user interface (312).
  • the user interface (312) guides a user through the capture and authentication operations.
  • An example of the user interface (312) is depicted in Figs. 4 and 5, Specifically, Fig. 4 illustrates a user interface (312) to initialize a capturing of a VDC (Fig. 1 , 104), according to an example of the principles described herein and Fig. 5 illustrates a user interface (312) to prompt authentication of the computing device (102), according to an example of the principles described herein.
  • the user interface (312) may display a button, or other interactive component.
  • the acquire engine (Fig. 3, 308) of the computing device (102) is activated.
  • a camera, scanner, or other capture device may be activated that allows the user to capture an image of a printed VDC (Fig. 1 , 104) or otherwise acquire information from a VDC (Fig. 1 , 104) that is not a printed component.
  • the user interface (312) may prompt the user for input regarding a form of authentication as depicted in Fig. 5. As can be seen in Fig. 5, a user may be prompted to select one of many types of authentication information.
  • the user is selecting which type of authentication information will be collected, and passed to the authentication engine (Fig. 1 , 106) for use in authenticating the computing device (102).
  • Fig. 5 depicts specific types of authentication information, any of various types of information may be selected, and collected by the authentication engine (Fig. 1 , 108) to authenticate the associated computing device (102).
  • the interface (312) displayed at the acquisition and authentication stages are both customizable. That is, each interface (312) can be customized to a certain device class, operating system, version, relation to contents of package featuring a VDC (Fig. 1 , 104), application-specific constraints, etc. As a specific example, some applications may just use an indication of possession of a computing device (Fig. 1 , 102) to direct workflows, whereas, at the other end of the spectrum, others may use possession and additional knowledge to establish an identity. In a specific example, a package containing sensitive legal documents may allow a subset of authentication options, such as biometrics and username/password
  • machine-specific identifiers such as an !MEA
  • Fig. 6 is a flowchart illustrating a method (600) for authorizing workflows following computing device (Fig. 1 , 102) authentication, according to an example of the principles described herein.
  • data associated with a VDC (Fig. 1 , 104) is acquired (block 601 ). This operation may be performed as described above in connection with Fig, 2.
  • the computing device (Fig. 1 , 102) that acquired the data is then authenticated (block 602). This operation, too, may be performed as described in connection with Fig. 2.
  • the computing device (Fig. 1 , 102) may then receive (block 603) the downstream workflow.
  • the computing device (Fig. 1 , 102) may receive the workflow from a server.
  • the interactions with any remote computing device (Fig, 1 , 102) may be secured through state-of-the-art encryption, certification and/or other methods, in a specific example, a web browser of the computing device (Fig. 1 , 102) is directed, via a secured connection, to a URL that includes commands to execute the workflow, in another implementation, the computing device (Fig. 1 , 102) may generate subsequent operations of processing based on an acquired VDC (Fig. 1 , 104) and authentication data.
  • an update to the downstream workflow is also received (block 604).
  • both the initial workflow, and the update to the downstream workflow occur after generation of the VDC (Fig. 1 , 104) and after acquisition of the authentication information.
  • updates to the workflow such as changes based on a role of the user, or updates based on changes to the product may constitute a change to the workflow.
  • the update to the workflow does not alter the mapping from 1 ) the data encoded in the VDC and 2) the authentication information to the corresponding workflow. In other examples, however, the mapping may be updated.
  • the downstream workflow is then authorized (block 605) which may be performed as described above in connection with Fig. 2.
  • triggering of the downstream workflow may include prompting (block 606) a capture of a secondary VDC.
  • This secondary VDC may correspond to one of a group of secondary VDCs that each trigger a role-specific workflow. Some from the group of secondary VDCs may have no corresponding workflow so as to confuse data-mining bots and other potential counterfeiters, thus impeding their efforts to counterfeit or breach the security of the subsequent workflows.
  • Fig, 7 is a diagram of a system (714) for authorizing workflows following computing device (Fig. 1 , 102) authentication, according to an example of the principles described herein.
  • the system (714) is a component of the computing device (Fig. 1 , 102).
  • the system (714) includes a processor (716) and a machine-readable storage medium (718) coupled to the processor (716).
  • the processor (716) may include other resources used to process programmed instructions.
  • the processor (716) may be a number of central processing units (CPUs), microprocessors, and/or other hardware devices suitable for retrieval and execution of instructions stored in machine- readable storage medium (718). in the system (714) depicted in Fig. 7, the processor (718) may fetch, decode, and execute instructions (720, 722, 724, 726) to authorize workflows following computing device (Fig. 1 , 102)
  • the processor (716) may include a number of electronic circuits comprising a number of electronic components for performing the functionality of a number of the instructions in the machine-readable storage medium (718).
  • executable instruction representations e.g., boxes
  • part or ail of the executable instructions and/or electronic circuits included within one box may, in alternate examples, be included in a different box shown in the figures or in a different box not shown.
  • the machine-readable storage medium (718) represent generally any memory capable of storing data such as programmed instructions or data structures used by the system (714).
  • the machine-readable storage medium (718) includes a machine-readable storage medium that contains machine- readable program code to cause tasks to be executed by the processor (716).
  • the machine-readable storage medium (718) may be tangible and/or non- transitory storage medium.
  • the machine-readable storage medium (718) may be any appropriate storage medium that is not a transmission storage medium.
  • the machine-readable storage medium (718) may be any electronic, magnetic, optical, or other physical storage device that stores executable instructions.
  • machine-readable storage medium (718) may be, for example, Random Access Memory (RAM), an Electrically-Erasable Programmable Read-Oniy Memory (EEPROM), a storage drive, an optical disc, and the like.
  • the machine-readable storage medium (718) may be disposed within the system (714), as shown in Fig. 7. In this situation, the executable instructions may be "installed" on the system (714).
  • the machine- readable storage medium (718) may be a portable, external or remote storage medium, for example, that allows the system (714) to download the instructions from the portable/external/remote storage medium, in this situation, the executable instructions may be part of an "installation package".
  • Prompt instructions (726) when executed by a processor (716), may cause the system (714) to prompt a user to capture one of a group of VDCs.
  • a total number of VDCs in the group is greater by at least two than the number of VDCs that trigger downstream workflows.
  • the processor (716) and machine-readable storage medium (718) are located within the same physical component, such as a server, or a network component.
  • the machine-readable storage medium (718) may be part of the physical component's main memory, caches, registers, non-volatile memory, or elsewhere in the physical components memory hierarchy.
  • the machine-readable storage medium (718) may be in communication with the processor (716) over a network.
  • the system (714) may be implemented on a user computing device, on a server, on a collection of servers, or combinations thereof.
  • the system (714) of Fig. 7 may be part of a general purpose computer. However, in alternative examples, the system (714) is part of an application specific integrated circuit. [0077] Using such a method and system 1 ) ties access to subsequent workflows to computing device authentication; 2) enhances security of authentication information; 3) provides for fully customizable workflows based on the automated or manual identification of the computing device; 4) provides roles-based access control workflows; 5) allows for definition of workflows before or in real-time based on information acquired about the computing device; 6) facilitates adaptive workflows while using the same VDCs; 7) facilitates the identification of fraudulent users; and 8) dissuades data-mining by insidious third parties.
  • the devices disclosed herein may provide utility in addressing other matters and deficiencies in a number of technical areas. Therefore, the systems and methods disclosed herein should not be construed as addressing any of the particular matters.
  • the computer usable program code may be embodied within a computer readable storage medium, the machine-readable storage medium being part of a computer program product.
  • the computer readable storage medium is a non-transitory machine-readable storage medium.

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Strategic Management (AREA)
  • Economics (AREA)
  • Entrepreneurship & Innovation (AREA)
  • General Business, Economics & Management (AREA)
  • Marketing (AREA)
  • Human Resources & Organizations (AREA)
  • Accounting & Taxation (AREA)
  • Development Economics (AREA)
  • Finance (AREA)
  • Computer Hardware Design (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Computing Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Tourism & Hospitality (AREA)
  • Quality & Reliability (AREA)
  • Operations Research (AREA)
  • Health & Medical Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Power Engineering (AREA)
  • Biomedical Technology (AREA)
  • Electromagnetism (AREA)
  • Toxicology (AREA)
  • Artificial Intelligence (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Data Mining & Analysis (AREA)
  • Educational Administration (AREA)
  • Game Theory and Decision Science (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

In one example in accordance with the present disclosure, a method is described. According to the method, a computing device acquires data related to a variable data component. The computing device then authenticates at least one of the computing device and the proper user of the computing device. Upon authentication of the computing device and/or proper user of the computing device, a downstream workflow is authorized. The downstream workflow is defined by the data associated with the variable data component and enabled via the authentication of the computing device and/or proper user of the computing device.

Description

WOR FLO -AUTHORIZING COMPUTING DEVICE AUTHENTICATION
BACKGROUND
[0001] Variable data components (VDCs) are machine-readable components that contain embedded information. The embedded information, upon extraction, can perform any number of functions or trigger any number of workflows. For example, a scanning device of a mobile device can capture a printed variable data component. A processor of the mobile device can then extract the embedded information; which information could direct a web browser of the mobile device to a particular website. Such variable data components can also be used in the detection of counterfeit products. The VDCs can also be used to drive the stages of other multi-stage interactions.
BRIEF DESCRIPTION OF THE DRAWINGS
[0002] The accompanying drawings illustrate various examples of the principles described herein and are a part of the specification. The illustrated examples are given merely for illustration, and do not limit the scope of the claims.
[0003] Fig. 1 is a diagram of an environment for authorizing workflows following computing device authentication, according to an example of the principles described herein.
[0004] Fig. 2 is a flowchart illustrating a method for authorizing workflows following computing device authentication, according to an example of the principles described herein. [0006] Fig. 3 is a diagram of a computing device that authorizes workflows following computing device authentication, according to an example of the principles described herein.
[0006] Fig. 4 illustrates a user interface to initialize capturing a variable data component, according to an example of the principles described herein.
[0007] Fig. 5 illustrates a user interface to prompt authentication of the computing device, according to an example of the principles described herein.
[0008] Fig. 6 is a flowchart illustrating a method for authorizing workflows following computing device authentication, according to an example of the principles described herein.
[0009] Fig. 7 is a diagram of a computing system for authorizing workflows following computing device authentication, according to another example of the principles described herein.
[0010] Throughout the drawings, identical reference numbers designate similar, but not necessarily identical, elements.
DETAILED DESCRIPTION
[0011] Variable data component(s) (VDCs) can be used to encode information. The encoded information, once extracted, can be used to perform any number of functions. For example, encoded information in a VDC can be used to trigger subsequent workflows. As a specific exam le, a user may scan a QR code located at a bus stop with an image scanning tool (e.g., camera) of a mobile device, information encoded in the QR code could direct the web browser of the mobile device to a web page that displays bus route information for busses passing that stop.
[0012] VDCs can also be used to assist in the detection of counterfeit products. For example, a printed VDC could be placed on a product package. A scanner of a mobile device can capture the VDC. A processor of the mobile device then parses the VDC to retrieve the embedded information, in some examples, the embedded information includes an electronic security image that is returned to the mobile device. If the electronic security image matches a security image printed on the product package, a user may have some measure of confidence that the product is authentic. Otherwise, the user may not wish to proceed further with any downstream workflow. That is, if the printed security image does not match the transmitted security image, a user can acknowledge that the associated product may be counterfeit. While specific workflows are described herein, specifically as they relate to product authentication, the VDC as described herein may be used to trigger any number of downstream workflows.
[0013] While such VDCs are useful in executing subsequent workflows and to some degree defecting counterfeit products, some characteristics of the environment in which the VDCs are used limit adoption of these techniques to specific types of workflows. For example, any workflow triggered by the scanning of a VDC is generic, and not user-specific. Returning to the above example, any computing device, or any user who scans a QR code at a bus stop will receive the same information, regardless of the identity of the user. Accordingly, fully customizable role-based workflows that are generated and executed based on device-specific information are not possible.
[0014] Still further, VDCs as used to authenticate products can be data- mined. For example, a data-mining bot, i.e., a computing application that runs automated scripts, can attempt to replicate a security image. In this example, an insidious third party can then print the replicated security image and fraudulently place that security image on a counterfeit product. More
specificaiiy, the bot could scan a barcode or generate permutations of numerical combinations represented by a barcode, and then poll the networked computing device for all variations of an associated security mark, which security mark could be a guiiloche or other graphical alphanumeric (that is, set of symbols representing specific codes or strings), in other words, the security mark may be any type of mark in which a large plurality of different symbols and/or symbol sets can be rendered. A counterfeiter could then place the guiiloche on their own product, thus confusing consumers as to the authenticity of a particular product. [0016] Accordingly, to enhance the customization of workflows triggered by interacting with a VDC and to enhance security of these workflows, the present specification describes a computing device authentication operation that 1 ) improves the security of the downstream workflows and 2) provides customizable workflows that are enabled via information gathered regarding the computing device during an authentication operation. Such customizable workflows allow for tailored workflows based on user-specific or device-specific information.
[0016] This customized workflow enablement is carried out after a computing device is authenticated. During such an authentication process, information about the computing device, which computing device may be tied to a particular user, is acquired. This information can be used to select, define, or interactively select among options to direct a downstream workflow.
Such authentication includes user interaction such that the downstream workflows are just accessible after the device is authenticated, in an example, subsequent workflow stages are determined based on which authenticated users/devices are authorized to continue with stages associated with various roles. Put another way, depending on the role authorized to proceed based on given authentication information (which could include validated or inauthentic identifiers/credentials), the content available via the subsequent stages of the workflow can be limited appropriately.
[0017] The present specification describes a method. According to the method, a computing device acquires data encoded in a VDC. The computing device then authenticates the computing device and/or a proper user of the computing device. A proper user is a user that is authenticated using
authentication criteria selected based on the target workflow. Upon
authentication of the computing device and/or proper user of the computing device, a downstream workflow is authorized. The downstream workflow is defined by the data encoded in the variable data component and enabled via the authentication of the computing device and/or the proper user of the computing device. [0018] The present specification also describes a computing device. The computing device includes an acquire engine to acquire data encoded in a VDC. An authentication engine of the computing device authenticates the computing device and/or a proper use of the computing device. A workflow engine of the computing device authorizes a downstream workflow. The downstream workflow is 1 ) defined by data encoded in the VDC and information acquired during authentication of the computing device and/or a proper user of the computing device and 2) enabled via the authentication of the computing device and/or the proper user of the computing device. The computing device also includes a user interface to receive user input information referenced during authentication.
[0019] Still further, the present specification describes a computing system that includes a processor and a machine-readable storage medium coupled to the processor. An instruction set is stored in the machine-readable storage medium and is to be executed by the processor. The instruction set includes instructions to capture an image of a printed VDC and upon capturing the image of the printed VDC, authenticate the computing device and/or a proper user of the computing device. The instruction set also includes instructions to, upon authentication of the computing device and/or proper user of the computing device, authorize a downstream workflow. As described above, the downstream workflow is defined by data encoded in the printed VDC and enabled via the authentication of the computing device and/or proper user of the computing device. The instruction set also includes instructions to, upon authorizing the downstream workflow, prompt a user to capture another one of a group of printed VDCs. A subset of the group of VDCs triggers a subsequent workflow and the number of printed VDCs that each trigger a subsequent workflow is fewer than or equal to the number of printed VDCs in the group, [0020] Using such a method and system 1 ) ties access to subsequent workflows to computing device authentication; 2) enhances security of authentication information; 3) provides for fully customizable workflows based on the automated or manual identification of the computing device; 4) provides role-based access control workflows; 5) allows for definition of workflows before or in real-time based on information acquired about the computing device; 6) facilitates adaptive workflows while using the same variable data components; 7) facilitates the identification of fraudulent users; and 8) dissuades data-mining by insidious third parties. However, it is contemplated that the devices disclosed herein may provide utility in addressing other matters and deficiencies in a number of technical areas. Therefore, the systems and methods disclosed herein should not be construed as addressing any of the particular matters.
[0021] As used in the present specification and in the appended claims, the term "workflow" refers to a defined series of computer-based tasks to produce a final outcome. Each stage in a series that makes up the workflow generally has inputs and produces outputs (including simply "states") that transforms data. Accordingly, a role-based workflow refers to a workflow with a plurality of sequences whose number and order can be specified beforehand and associated with a given role for a given user, user type, or agent.
[0022] Further, as used in the present specification and in the appended claims, the term "variable data component" refers to a component that can be interrogated (i.e. , scanned, decoded, etc.) by a computing device and that stores encoded information. The variable data component may be printed, such as a barcode, or affixed to a surface such as an RF!D chip. The variable data component may be physical as in the example of a printed or affixed variable data component, or it may be virtual, as in an image on a computer screen.
[0023] Still further, as used in the present specification and in the appended claims, the term "authentication information" refers to information utilized during authentication of a computing device and/or proper user of the computing device, and any subsequent determinations of workflow stages. For example, the authentication could include information relating to an owner of the computing device or a unique identifier of the computing device, among others.
[0024] Yet further, as used in the present specification and in the appended claims, the term "proper user" refers to a user that is paired with the computing device, sometimes uniquely, for example via biometric association of the user with the computing device. [0026] Even further, as used in the present specification and in the appended claims, the term "a number of" or similar language is meant to be understood broadly as any positive number including 1 to infinity; zero not being a number, but the absence of a number.
[0026] In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present systems and methods. It will be apparent, however, to one skilled in the art that the present apparatus, systems, and methods may be practiced without these specific details. Reference in the specification to "an example" or similar language indicates that a particular feature, structure, or characteristic described in connection with that example is included as described, but may not be included in other examples.
[0027] Fig, 1 is a diagram of an environment (100) for authorizing workflows following computing device (102) authentication, according to an example of the principles described herein. As described above, variable data components, or VDCs, (104) can be used to trigger workflows on the computing device (102). Accordingly, a VDC (104) can be any image, symbol, or other component that includes or references encoded information. Such VDCs (104) may be printable such as a guilioche or other graphical alphanumeric, 2D matrix, barcode, QR code or any visual mark that is suitable for printing, in some examples, the VDC (104) is not printable but is a physical component that could be affixed to a surface. An RFID chip or other memory device are other examples of such a physical VDC (104), Still further, while Fig. 1 depicts a VDC (104) printed on a substrate, the VDC (104) may also be an electronic component, such as an image displayed on an electronic screen.
[0028] Returning to the environment (100), in a first operation a user employs a computing device (102) having a capture device such as a scanner or a camera. Using this capture device, the user acquires data encoded by the VDC (104). Specifically, as depicted in Fig. 1 , a camera or scanner can capture a digital image of a printed VDC (104). In the case where the VDC (104) is an RFID chip, the user computing device (102) may include an RFID reader that can read variable bit streams, in yet another example, the VDC may be a small on-chip memory, and the capture device could be an embedded memory reader to read the small on-chip memory. While Fig, 1 depicts a mobile phone as the computing device (102), any type of computing device (102) may be
implemented in accordance with the principles described herein. Other examples of computing devices (102) include a personal computing device, a notebook, laptop computer, a tablet, a gaming system, or other computing device (102) that has the capability of capturing a VDC (104) and processing data encoded therein.
[0029] The VDC (104) may include encoded information that is interpreted by the computing device (102). For example, the VDC (104) may include information that at least in part identifies subsequent workflows that may be executed. This information, when used in conjunction with data gathered about the computing device (102) during authentication, authorizes role-specific workflows that may be a subset of workflows identified by data encoded in the VDC (104). The VDC (104) may also include information that triggers an authentication engine (106) of the computing device (102). The authentication engine (106) is indicated as a dashed-box indicating its location internal to the computing device (102). The authentication engine (106) uses authentication information relating to the computing device (102) or a user associated with the computing device (102) to authenticate the computing device (102) and accordingly authorize subsequent user-specific workflows.
[0030] In general, the authentication engine (106) facilitates
authentication which allows those providing workflows to make some
determination as to whether the device and/or user are what and/or who they should be. Various workfiow-providing services or applications may implement different levels of assurance. If the device and/or user of the device fails to authenticate, subsequent workflows may be limited or even prevented for users whose roles are associated with identifiers and/or credentials that cannot be validated.
[0031] There may be varying levels of authentication performed. For example, at a first level, possession of a computing device (102) may be sufficient. In this example, an identifier of the computing device (102) may be sufficient to authenticate. At another level, in addition to possession of the device, knowledge of the device or a user of the device, i.e., a username and password, may be used to authenticate. At yet another level, an identity of a user may be verified, for example via biometric information gathered about the user. The authentication engine (106) can be used in part to acquire these components as well as identify which level of authentication is to be used for a particular workflow/role.
[0032] Accordingly, the authentication engine (106) may provide some authentication information, which may include, be derived from, or tied to, some representation of an identifier, or some form of credentials, either directly describing the device such as a media access control (MAC) address, or a UDID number, or associated with the device. However, even if the service can validate that the device and/or user are as the service thinks they should be, workflows may be directed by which devices and/or users are authorized to access content downstream. Thus, the authentication engine (106) determines authentication information that can be associated with the role of a user of that device.
[0033] The authentication engine (106) can either manually or automatically obtain authentication information from the computing device (102) and uses such authentication information to verify that the associated computing device (102) is permitted to access subsequent workflows, in some examples, authentication information obtained during the authentication process may include personal information about a user of the computing device (102). This personal information could be used to select and/or define the workflow that is authorized.
[0034] When the computing device (102) is authenticated, a subsequent workflow that is encoded in, or referenced by, the VDC (104) and that is defined, at least in part, by information collected during the authentication, is authorized and triggered. By comparison, if the computing device (102) is not authenticated, then the computing device (102) may be prevented from executing subsequent workflows, thus enhancing the security of workflows. [0036] In this environment, using an authentication engine (106) to authenticate the computing device (102) and/or a proper user of the computing device (102), prior to a triggering of subsequent role-specific workflows, i.e., authorizing the workflow, discourages data-mining. For example, the operation to enter information related to the computing device (102), i.e., adding a role- specific identification, allows for the discernment of counterfeiting. The increased ability to discern a counterfeit operation may dissuade data-mining, i.e., collecting the data associated with activating a workflow that the data-miner has no role-based right to act upon, as it would be less effective.
[0036] Moreover, by requiring the user to enter information related to the computing device (102) during authentication, subsequent workflows may be triggered that are unique to the computing device (102) by being based on information specific to the computing device (102).
[0037] Fig. 2 is a flowchart illustrating a method (200) for authorizing workflows following computing device (Fig. 1 , 102) authentication, according to an example of the principles described herein. As a general note, the methods (200, 600) may be described below as being executed or performed by at least one device, for example, the computing device (Fig. 1 , 102). Other suitable systems and/or computing devices may be used as well. The methods (200, 600) may be implemented in the form of executable instructions stored on at least one machine-readable storage medium of at least one of the devices and executed by at least one processor of at least one of the devices. In one implementation, the machine-readable storage medium may include a standalone program installed on the device. In another implementation, the machine-readable medium may include instructions delivered by a browser on the device. Alternatively, or in addition, the methods (200, 600) may be implemented in the form of electronic circuitry (e.g., hardware). While Figs. 2 and 6 depict operations occurring in a particular order, a number of the operations of the methods (200, 600) may be executed concurrently or in a different order than shown in Figs. 2 and 6. In some examples, the methods (200, 600) may include more or fewer operations than are shown in Figs. 2 and 6. in some examples, a number of the operations of the methods (200, 600) may, at certain times, be ongoing and/or may repeat. [0038] According to the method (200), data associated with a VDC (Fig.1 , 104) is acquired (block 201 ) via a computing device (Fig. 1 , 102). For example, a computing device (Fig. 1 , 102) may include a camera, scanner, or other capturing device to capture a digital image of a printed VDC (Fig. 1 , 104). While specific reference is made to capturing an image of a printed VDC (Fig. 1 , 104), any method of interrogating a VDC (Fig. 1 , 104) that stores encoded data may be implemented. For example, if a non-printed VDC (Fig. 1 , 104), for example an RFiD chip is used, the computing device (Fig. 1 , 102) may include a reader component to acquire information stored in the RFID chip. Thus, the VDC (Fig. 1 , 104) refers to any image, symbol, or component that includes encoded data, or that references encoded data that can be interrogated by a computing device (Fig. 1 , 102) such as a mobile computing device.
[0039] The data associated with (i.e., encoded within or referenced by) the VDC (Fig. 1 , 104) may include various pieces of information. As one specific example, the VDC (Fig. 1 , 104) may include data regarding subsequent workflows and a command to authenticate the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig. 1 , 102). For example, the data acquired from the captured image can in part identify the different workflows. Then information about the computing device (Fig. 1 , 102) is received during authentication. Using both pieces of information a role-specific workflow as defined by the data associated with the VDC (Fig. 1 , 104) can be selected.
[0040] According to the method (200), the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig. 1 , 102) is then authenticated (block 202). The authentication (block 202) is performed using the computing device (Fig. 1 , 102) which utilizes various mechanisms in authenticating the computing device (Fig. 1 , 102). For example, computing devices (Fig. 1 , 102) may include various applications that either manually or automatically identify the computing device (Fig. 1 , 102). In some examples, authentication of the computing device (Fig. 1 , 102) is extended by authentication of the user or operator of the computing device (Fig. 1 , 102). For example, a user may be paired with a particular computing device (Fig. 1 , 102). As a specific example, a smartphone may include a biometrics reader that is initially set up to recognize a particular user's fingerprint. This information can be stored locally on the computing device (Fig. 1 , 102) so that a swipe with a finger of the particular user unlocks the computing device, even if a user is not able to access a carrier. A user that is paired with a particular computing device (Fig. 1 , 102) may be referred to as a "proper user" or "authorized user" of the computing device (Fig. 1 , 102). In some examples, a proper user is a user that has access to the computing device (Fig. 1 , 102) based on biometric information, which biomefric information may be stored on the computing device (Fig. 1 , 102). While some computing devices (Fig. 1 , 102), such as mobile phones, may allow one person to unlock the computing device (Fig. 1 , 102), other computing devices such as laptop computers can be set up to read the biometric information of any number of users. Once the appropriate level of authentication has been achieved, the user is then authorized to perform the associated workflows. That is, role-based access is then enabled.
[0041] In other words, the computing device (Fig. 1 , 102) can be authenticated by authentication of the user of the computing device (Fig. 1 , 102). Accordingly, in some cases, information related to the user of the computing device (Fig. 1 , 102) can authenticate the computing device (Fig. 1 , 102). Specific non-limiting examples of authentication of an operator of a computing device (Fig, 1 , 102) serving to authenticate the computing device (Fig. 1 , 102) are provided below.
[0042] In a first example, a password-protected computing device (Fig. 1 , 102) can be authenticated via entry of a username/password. If an incorrect username/password is entered, then the computing device (Fig. 1 , 102) cannot be authenticated, in a related example, login information for a particular social network service can also be used to authenticate the computing device (Fig. 1 , 102). As another example, biometric login information could be used to authenticate the computing device (Fig. 1 , 102). For example, a computing device (Fig. 1 , 102) may include applications to acquire biometrics of the user. Examples of such applications include a fingerprint reader, a voice recognition application, and a facial recognition application among others. Accordingly, biometric information could be used to authenticate the computing device (Fig, 1 , 102).
[0043] Still further, other information that specifically identifies the computing device (Fig. 1 , 102) could be used in authenticating the computing device (Fig. 1 , 102). For example, the computing device (Fig, 1 , 102) may be assigned a unique identifier such as an international mobile equipment identify (IMEI) number, an international mobile subscriber identity (IMSI) number, a mobile equipment identifier (MEID), serial number, media access control (MAC) number, and electronic serial number (ESN), or other unique identifier of the computing device (Fig. 1 , 102). Such information could be leveraged during the authentication process.
[0044] As yet another example of authenticating a computing device (Fig. 1 , 102), a global-positioning signal (GPS) application could acquire information regarding the geographical positioning of the computing device (Fig. 1 , 102). If the GPS information indicates that the computing device (Fig. 1 , 102) is in an expected or valid position, the computing device (Fig. 1 , 102) can be
authenticated.
[004S] In yet another example of authenticating a computing device (Fig. 1 , 102), the authentication information may be purchase device authorization data. For example, it is possible to draw a link between a mechanism for purchasing products/services, i.e., a credit card, and the computing device (Fig. 1 , 102). If the purchasing mechanism data, i.e., credit card information, stored in the computing device (Fig. 1 , 102) is valid, the computing device (Fig. 1 , 102) can be authenticated, in still yet another example of authenticating a computing device (Fig.1 , 102), the payment authorization information may be entered by a user during authentication, or by swiping a payment card through a reader attached to the computing device (Fig. 1 , 102). While specific examples have been provided of different authentication information, other authentication information could also be used.
[0046] In some examples, the authentication information can be manually retrieved or automatically retrieved. During manual retrieval, a user may be prompted to enter username/password, social networking login information, GPS location, and/or purchase mechanism information during authentication. By comparison, in some examples such information may be cached, or in the cases of device identifiers, may be stored in system storage and can be obtained independent of user entry of such information. In this case, a user may provide authorization for acquisition and use of such authentication information.
[0047] Authentication (block 202) of the computing device (Fig. 1 , 102) may include comparison of the acquired authentication information against a database. For example, the computing device (Fig. 1 , 102) may include a database of valid authentication information. In one specific example using biometric authentication, it may be possible to verify a user via mechanisms local to a given device, but still prevent said user from accessing certain content if their authentication information is not found in the database. In another example, authentication (block 202) may include hashing of the acquired authentication information. For example, a username/password may be hashed and associated with a trusted platform module/chip on the computing device (Fig. 1 , 102). In yet another example, authentication may be achieved by comparing collected authentication information with various instances of authentication information associated with different roles, and selecting the best match.
[0048] In some cases, such authentication occurs on the computing device (Fig. 1 , 102) that was used to acquire the data associated with the VDC (Fig. 1 , 104). Specifically, as will be demonstrated below, the subsequent workflows that are executed, because they are based on computing device and/or device-mediated (Fig. 1 , 102) authentication, can be specific to the computing device (Fig, 1 , 102) and the computing device (Fig, 1 , 102) relationship to the owner. Accordingly, such authentication occurs through engines on, associated with, or used by, the computing device (Fig. 1 , 102).
[0049] After authentication (block 202) of the computing device (Fig. 1 , 102), authorization is granted to the downstream workflows. The computing device (Fig. 1 , 102) can then authorize (block 203) a downstream workflow based on information received via acquisition of data associated with the VDC (Fig, 1 , 104) as well as the authentication information of the computing device (Fig, 1 , 102) and/or proper user of the computing device (Fig. 1 , 102).
Specifically, in one example, the workflow that is executed is defined, at least in part, by the VDC (Fig. 1 , 104), and is enabled via the authentication of the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig. 1 , 102). For example, as described above the VDC (Fig. 1 , 104) either includes encoded information relating to the subsequent workflows or references a location where the subsequent workflows are stored, but it is due to the authentication of a computing device (Fig. 1 , 102) that a particular workflow is executed.
[00S0] In some examples, in addition to being defined by data included in the VDC (Fig. 1 , 104), the downstream workflows may be defined by
authentication information gathered during the authentication of the computing device (Fig. 1 , 102). For example, as described above, a computing device (Fig. 1 , 102) can be authenticated by obtaining information, such as
username/password, biometric information, privileged login information, among others, associated with a user of the computing device (Fig. 1 , 102). This information may include information regarding the operation of the computing device (Fig. 1 , 102), position within an organization of the user, demographic information of the user, and personal preferences. Such information can lead to a determination of a user's role and can be used to select or generate the desired workflow. Accordingly, based on information included or referenced by the VDC (Fig. 1 , 104) and the role of the currently authenticated computing device (Fig. 1 , 102), role-based workflows are implemented. In other words, a mapping is generated between the workflow data associated with the VDC (Fig. 1 , 104), data relating to the computing device (Fig. 1 , 102) and its associated user, and the permissions of the user relating to subsequent portions of the workflow, in one example, the workflow is defined by both the VDC (Fig. 1 , 104) and the authentication information of the computing device (Fig. 1 , 102), For example, an authenticated user may for instance, receive read access to some resources upon most validations of their identity, but may receive write access if biometric validation is provided. Accordingly, fully customizable workflows that are secure from insidious third parties, can be implemented, [0051] The downstream workflows that are authorized (block 203) may take many forms. For example, the downstream workflow could include the sending of a security-confidence mark that, when compared to a printed security-confidence mark, provides a user with confidence that subsequent workflows are valid. Note that the security-confidence mark may be distinct from the VDC (Fig. 1 , 104) described earlier, in the specific case of
authenticating a product, following computing device (Fig, 1 , 102)
authentication, a security image may be electronically transmitted to the computing device (Fig. 1 , 102). A user may then compare the electronically transmitted security image against a printed security image to ensure that they match. If they match, a user can have confidence that the associated product is authentic. If they do not match, a user can be tipped-off that a counterfeit or otherwise illicit action may have occurred.
[00S2] In another example, the downstream workflow includes the transmission of information specific to a user of the computing device (Fig. 1 , 102). For example, during authentication of the computing device (Fig. 1 , 102), certain information relating to the user of the computing device (Fig. 1 , 102) may have been obtained. This authentication information could be used to authorize a workflow that provides user-specific information.
[0053] As a specific example, a user may capture a VDC (Fig. 1 , 104) disposed on a food container, if a social network login is used to authenticate the computing device (Fig. 1 , 102), the additional workflow may include posting targeted advertisements on that user's social media page. While specific reference is made to advertising specific to the user, other types of information specific to the user may be provided based on the information acquired during authentication. Such information includes allergy information specific to the user, ingredient information, caloric information which could be transmitted to the user's dietary intake application, etc.
[0054] In yet another example, notifications of the user's action can be passed to a social networking application related to the corresponding
18 product/service associated with the VDC (Fig. 1 , 104). These are just a few examples, and many different types and forms of role-specific tasks may be executed by the workflows that are defined/generated based on the data associated with the VDC and information acquired during authentication of the computing device (Fig. 1 , 102).
[0055] In yet another example, the downstream workflow includes a command to trigger execution of an application to read hidden data within the VDC (Fig. 1 , 104). For example, some applications can read obfuscated information in a VDC (Fig, 1 , 104) which is unreadable by some scanners scanner. Such information includes color patterns, steganographic marks, or the like.
[00S6] In some examples, the downstream workflow includes a prompt to capture another one of a group of secondary VDCs. For example, the substrate on which the initial VDC (Fig. 1 , 104) is included may include other secondary VDCs. A subset of these secondary VDCs may trigger subsequent workflows. Accordingly, the prompt may indicate to a user which of the secondary VDCs triggers a workflow and which do not.
[00S7] In this example, each of the subset of secondary VDCs may trigger a different workflow, or different stages of a larger workflow. For example, one secondary VDC could be used to deliver customer loyalty points to a consumer, another secondary VDC could deliver a coupon, another secondary VDC could collect a donation contribution, and another secondary VDC could facilitate a social media purpose such as posting information to a social networking site. In this example, a user interface of the computing device (Fig. 1 , 102) may include an identification of secondary VDCs that trigger subsequent workflows, and what subsequent workflows are triggered.
[0058] Requiring authentication prior to executing workflows based on secondary VDCs reduces the efficacy of data-mining. For example, the number of secondary VDCs in the group that trigger subsequent workflows may be fewer than or equal to the number of secondary VDCs in the group. In other words, there may be some reserved, unused, or unexhausted secondary VDCs. Such reserve data marks reduce the likelihood of data-mining as a bot cannot collect all of the salient information automatically by polling a service with a large number of VDC values that are not used.
[00S9] According to the method (200) described herein, user interaction with the computing device (Fig. 1 , 102) via authentication enhances security by allowing a secure connection prior to execution of workflows defined by the data encoded in the VDC (Fig. 1 , 104). Further, by relying on information acquired about a user during device authentication, customizable role-based workflows may be generated.
[0060] Fig. 3 is a diagram of a computing device (102) for authorizing workflows following computing device (102) authentication, according to an example of the principles described herein. To achieve its desired functionality, the computing device (102) includes various hardware components.
Specifically, the computing device (102) includes a number of engines. The engines refer to a combination of hardware and program instructions to perform a designated function. The engines may be hardware. For example, the engines may be implemented in the form of electronic circuitry (e.g. , hardware). Each of the engines may include its own processor, but one processor may be used by ail the modules. For example, each of the engines may include a processor and memory. Alternatively, one processor may execute the designated function of each of the modules. Further, the engines may be distributed across hardware and machine-readable storage mediums of a variety of devices.
[0061] The acquire engine (308) acquires data encoded in the variable data component (Fig. 1 , 104). Specifically, the VDC (Fig. 1 , 104) may include encoded data that includes instructions regarding the execution of workflows and/or instructions directing an authentication engine (106) to authenticate the computing device (102). Accordingly, the acquire engine (308) may include components to decode the encoded information. The acquire engine (308) may include a scanner, camera or other capture device that captures a digital image of a printed variable data component (Fig. 1 , 104). Where the VDC (Fig. 1 , 104) is a RFID chip, the acquire engine (308) includes an RF reader that can acquire the RF!D and any associated information. The data acquired by the acquire engine (308) may trigger an authentication engine (108) to authenticate the computing device (102).
[0062] As described above, the authentication engine (106) relies on various types of authentication information, which may pertain to a user or operator of the computing device (102) to authenticate the computing device (102). Using such information, the authentication engine (106) can verify, via a number of methods, the computing device (102). This authentication may include finding an exact match for an identifier of the computing device (102) or performing a statistical analysis of biometric information relating to an operator of the computing device (102). Authentication may also include otherwise processing the information, i.e., hashing a username/password, to determine whether the hashed data string matches a valid hashed data string.
[0063] In some examples, the computing device (102) is authenticated by the user having an identity and possession of the computing device (102). That is, the computing device (102) is authenticated based on information associated with the owner/possessor of the computing device (102). In some
implementations, a processor of the computing device (102) may execute instructions stored on the computing device (102) that either compare the authentication information against a database or otherwise process the authentication information using a trusted module in order to authentication the computing device (102).
[0064] The computing device (102) also includes a workflow engine (310) that authorizes a downstream workflow. As described above, the downstream workflow is 1 ) defined by at least data encoded, or otherwise referenced, in the VDC (Fig. 1 , 104) as well as information acquired during authentication of the computing device (102) and 2) enabled via the authentication of the computing device (102). Accordingly, the authorized workflow may be user or role-specific to the owner of the computing device (102). in some examples, the workflow engine (310) receives the workflow that is to be executed after generation of the associated VDC (Fig. 1 , 104). For example, a VDC (Fig. 1 , 104) could be generated that includes a URL that includes the commands associated with carrying out a workflow. These commands may be generated after the VDC (Fig. 1 , 104) is printed and affixed to a substrate. As a specific example, a VDC (Fig. 1 , 104) could be printed and affixed to a product package. The initial workflow associated with the VDC (Fig. 1 , 104) may present product information such as links to drivers, advertising material, etc. If at a point after generation of the VDC (Fig. 1 , 104) product information changes, i.e., a recall or a particular advertising campaign ends, the workflow operations as identified in the URL may be changed, while retaining the previous mapping between the URL and the then existing VDC (Fig. 1 , 104). Doing so is beneficial in that it allows for customizable, and updatable workflows, all while being associated with a single VDC (Fig. 1 , 104) that has already been printed, and therefore does not justify a re-printing following the update to the associated workflow.
[0065] The computing device (102) also includes a user interface (312). In addition to other functions, the user interface (312) guides a user through the capture and authentication operations. An example of the user interface (312) is depicted in Figs. 4 and 5, Specifically, Fig. 4 illustrates a user interface (312) to initialize a capturing of a VDC (Fig. 1 , 104), according to an example of the principles described herein and Fig. 5 illustrates a user interface (312) to prompt authentication of the computing device (102), according to an example of the principles described herein.
[0066] As depicted in Fig. 4, the user interface (312) may display a button, or other interactive component. Once such a component is selected, the acquire engine (Fig. 3, 308) of the computing device (102) is activated. For example, a camera, scanner, or other capture device may be activated that allows the user to capture an image of a printed VDC (Fig. 1 , 104) or otherwise acquire information from a VDC (Fig. 1 , 104) that is not a printed component. Once such information is captured, the user interface (312) may prompt the user for input regarding a form of authentication as depicted in Fig. 5. As can be seen in Fig. 5, a user may be prompted to select one of many types of authentication information. In other words, the user is selecting which type of authentication information will be collected, and passed to the authentication engine (Fig. 1 , 106) for use in authenticating the computing device (102). While Fig. 5 depicts specific types of authentication information, any of various types of information may be selected, and collected by the authentication engine (Fig. 1 , 108) to authenticate the associated computing device (102).
[0067] Further, in some examples, the interface (312) displayed at the acquisition and authentication stages are both customizable. That is, each interface (312) can be customized to a certain device class, operating system, version, relation to contents of package featuring a VDC (Fig. 1 , 104), application-specific constraints, etc. As a specific example, some applications may just use an indication of possession of a computing device (Fig. 1 , 102) to direct workflows, whereas, at the other end of the spectrum, others may use possession and additional knowledge to establish an identity. In a specific example, a package containing sensitive legal documents may allow a subset of authentication options, such as biometrics and username/password
combinations, since machine-specific identifiers (such as an !MEA) may not exhibit a relationship with a user.
[0068] Fig. 6 is a flowchart illustrating a method (600) for authorizing workflows following computing device (Fig. 1 , 102) authentication, according to an example of the principles described herein. According to the method (600), data associated with a VDC (Fig. 1 , 104) is acquired (block 601 ). This operation may be performed as described above in connection with Fig, 2. The computing device (Fig. 1 , 102) that acquired the data is then authenticated (block 602). This operation, too, may be performed as described in connection with Fig. 2.
[0069] The computing device (Fig. 1 , 102) may then receive (block 603) the downstream workflow. In one implementation, the computing device (Fig. 1 , 102) may receive the workflow from a server. The interactions with any remote computing device (Fig, 1 , 102) may be secured through state-of-the-art encryption, certification and/or other methods, in a specific example, a web browser of the computing device (Fig. 1 , 102) is directed, via a secured connection, to a URL that includes commands to execute the workflow, in another implementation, the computing device (Fig. 1 , 102) may generate subsequent operations of processing based on an acquired VDC (Fig. 1 , 104) and authentication data. In some cases, an update to the downstream workflow is also received (block 604), In some examples, both the initial workflow, and the update to the downstream workflow occur after generation of the VDC (Fig. 1 , 104) and after acquisition of the authentication information. For example, updates to the workflow, such as changes based on a role of the user, or updates based on changes to the product may constitute a change to the workflow. In some examples, the update to the workflow does not alter the mapping from 1 ) the data encoded in the VDC and 2) the authentication information to the corresponding workflow. In other examples, however, the mapping may be updated.
[0070] Following receiving the initial workflow and any updates, the downstream workflow is then authorized (block 605) which may be performed as described above in connection with Fig. 2. Upon authentication, triggering of the downstream workflow may include prompting (block 606) a capture of a secondary VDC. This secondary VDC may correspond to one of a group of secondary VDCs that each trigger a role-specific workflow. Some from the group of secondary VDCs may have no corresponding workflow so as to confuse data-mining bots and other potential counterfeiters, thus impeding their efforts to counterfeit or breach the security of the subsequent workflows.
[0071] Fig, 7 is a diagram of a system (714) for authorizing workflows following computing device (Fig. 1 , 102) authentication, according to an example of the principles described herein. In some examples, the system (714) is a component of the computing device (Fig. 1 , 102). The system (714) includes a processor (716) and a machine-readable storage medium (718) coupled to the processor (716). Although the following descriptions refer to a single processor (716) and a single machine-readable storage medium (718), the descriptions may also apply to a system (714) with multiple processors and multiple machine-readable storage mediums, in such examples, the instructions may be distributed (e.g., stored) across multiple machine-readable storage mediums and the instructions may be distributed (e.g., executed by) across multiple processors. [0072] The processor (716) may include other resources used to process programmed instructions. For example, the processor (716) may be a number of central processing units (CPUs), microprocessors, and/or other hardware devices suitable for retrieval and execution of instructions stored in machine- readable storage medium (718). in the system (714) depicted in Fig. 7, the processor (718) may fetch, decode, and execute instructions (720, 722, 724, 726) to authorize workflows following computing device (Fig. 1 , 102)
authentication. As an alternative or in addition to retrieving and executing instructions, the processor (716) may include a number of electronic circuits comprising a number of electronic components for performing the functionality of a number of the instructions in the machine-readable storage medium (718). With respect to the executable instruction representations (e.g., boxes) described and shown herein, it should be understood that part or ail of the executable instructions and/or electronic circuits included within one box may, in alternate examples, be included in a different box shown in the figures or in a different box not shown.
[0073] The machine-readable storage medium (718) represent generally any memory capable of storing data such as programmed instructions or data structures used by the system (714). The machine-readable storage medium (718) includes a machine-readable storage medium that contains machine- readable program code to cause tasks to be executed by the processor (716). The machine-readable storage medium (718) may be tangible and/or non- transitory storage medium. The machine-readable storage medium (718) may be any appropriate storage medium that is not a transmission storage medium. For example, the machine-readable storage medium (718) may be any electronic, magnetic, optical, or other physical storage device that stores executable instructions. Thus, machine-readable storage medium (718) may be, for example, Random Access Memory (RAM), an Electrically-Erasable Programmable Read-Oniy Memory (EEPROM), a storage drive, an optical disc, and the like. The machine-readable storage medium (718) may be disposed within the system (714), as shown in Fig. 7. In this situation, the executable instructions may be "installed" on the system (714). Alternatively, the machine- readable storage medium (718) may be a portable, external or remote storage medium, for example, that allows the system (714) to download the instructions from the portable/external/remote storage medium, in this situation, the executable instructions may be part of an "installation package".
[0074] Referring to Fig. 7, capture instructions (720), when executed by a processor (716), may cause the system (714) to capture an image of a printed VDG (Fig. 1 , 104). Authenticate instructions (722), when executed by a processor (716), may cause the system (714) to, upon capturing the image of the printed VDC (Fig. 1 , 104), authenticate the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig. 1 , 102). Workflow instructions (724), when executed by a processor (716), may cause the system (714) to, upon authentication of the computing device (Fig. 1 , 102) and/or proper user of the computing device (Fig.1 s 102), authorize a downstream workflow that is 1 ) defined by data encoded in the VDC (Fig. 1 , 104) and 2) enabled via the authentication of the computing device (Fig. 1 , 102). Prompt instructions (726), when executed by a processor (716), may cause the system (714) to prompt a user to capture one of a group of VDCs. In some examples, a total number of VDCs in the group is greater by at least two than the number of VDCs that trigger downstream workflows.
[0075] In some examples, the processor (716) and machine-readable storage medium (718) are located within the same physical component, such as a server, or a network component. The machine-readable storage medium (718) may be part of the physical component's main memory, caches, registers, non-volatile memory, or elsewhere in the physical components memory hierarchy. Alternatively, the machine-readable storage medium (718) may be in communication with the processor (716) over a network. Thus, the system (714) may be implemented on a user computing device, on a server, on a collection of servers, or combinations thereof.
[0076] The system (714) of Fig. 7 may be part of a general purpose computer. However, in alternative examples, the system (714) is part of an application specific integrated circuit. [0077] Using such a method and system 1 ) ties access to subsequent workflows to computing device authentication; 2) enhances security of authentication information; 3) provides for fully customizable workflows based on the automated or manual identification of the computing device; 4) provides roles-based access control workflows; 5) allows for definition of workflows before or in real-time based on information acquired about the computing device; 6) facilitates adaptive workflows while using the same VDCs; 7) facilitates the identification of fraudulent users; and 8) dissuades data-mining by insidious third parties. However, it is contemplated that the devices disclosed herein may provide utility in addressing other matters and deficiencies in a number of technical areas. Therefore, the systems and methods disclosed herein should not be construed as addressing any of the particular matters.
[0078] Aspects of the present system and method are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to examples of the principles described herein. Each block of the flowchart illustrations and block diagrams, and combinations of blocks in the flowchart illustrations and block diagrams, may be implemented by computer usable program code. The computer usable program code may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the computer usable program code, when executed via, for example, the processor (716) of the system (714) or other programmable data processing apparatus, implements the functions or acts as specified in the flowchart and/or block diagram block or blocks. In one example, the computer usable program code may be embodied within a computer readable storage medium, the machine-readable storage medium being part of a computer program product. In one example, the computer readable storage medium is a non-transitory machine-readable storage medium. [0079] The preceding description has been presented to illustrate and describe examples of the principles described. This description is not intended to be exhaustive or to limit these principles to any precise form disclosed. Many modifications and variations are possible in light of the above teaching.
28

Claims

CLAIMS WHAT IS CLAIMED IS:
1 . A method comprising:
with a computing device, acquiring data associated with a variable data component;
with the computing device, authenticating at least one element selected from the group consisting of the computing device and a proper user of the computing device; and
upon authentication of the at least one element selected from the group consisting of the computing device and a proper user of the computing device, authorizing a downstream workflow, wherein the workflow is:
defined by the data associated with the variable data component; and
enabled via the authentication of the at least one element selected from the group consisting of the computing device and a proper user of the computing device.
2. The method of claim 1 , wherein the workflow is further defined by information gathered during authentication of the at least one element selected from the group consisting of the computing device and the proper user of the computing device,
3. The method of claim 1 , further comprising receiving the downstream workflow, which downstream workflow is associated with the variable data component.
4. The method of claim 3, further comprising receiving an update to the downstream workflow, which update is generated after the creation of the variable data component.
5. The method of claim 1 , wherein:
the downstream workflow comprises a prompt to capture one of a group of secondary variable data components;
each secondary variable data component of a subset of the group of secondary variable data components triggers a subsequent workflow; and the number of secondary variable data components in the subset is fewer than or equal to the number of secondary variable data components in the group.
6. The method of claim 1 , wherein the downstream workflow comprises providing information specific to a user of the computing device.
7. A computing device comprising:
an acquire engine to acquire data encoded in a variable data component;
an authentication engine to authenticate at least one element selected from the group consisting of the computing device and a proper user of the computing device;
a workflow engine to trigger a downstream workflow, wherein the downstream workflow is:
defined by data encoded in the variable data component and information acquired during authentication of the at least one element selected from the group consisting of the computing device and the proper user of the computing device; and
enabled via the authentication of the at least one element selected from the group consisting of the computing device and the proper user of the computing device; and
a user interface to receive user input referenced during
authentication.
8. The device of claim 7, wherein the variable data component is a printed variable data component.
9. The device of claim 7, wherein the downstream workflow comprises a command to trigger execution of an application to read hidden data in the variable data component.
10. The device of claim 7, wherein the authentication engine
authenticates the computing device using at least one of the computing elements selected from the group consisting of user biometric login data, username/password data, device uniqueness identification data, global positioning information, and device payment authorization information.
1 1 . The device of claim 7, wherein the workflow engine triggers a downstream workflow that is generated after the generation of the variable data component.
12. The device of claim 7, wherein the user interface prompts a user to select one of multiple computing device authentication formats.
13. A computing system comprising:
a processor;
a machine-readable storage medium coupled to the processor; and an instruction set stored in the machine-readable storage medium to be executed by the processor, wherein the instruction set comprises:
instructions to capture an image of a printed variable data component;
instructions to, upon capturing the image of the printed variable data component, authenticate at least one element selected from the group consisting of the computing device and a proper user of the computing device;
instructions to, upon authentication of the at least one element selected from the group consisting of the computing device and a proper user of the computing device, authorize a downstream workflow, wherein the downstream workflow is: defined by data encoded in the printed variable data component; and
enabled via the authentication of the at least one element selected from the group consisting of the computing device and the proper user of the computing device; and instructions to, upon authorizing the downstream workflow, prompt a user to capture one of a group of secondary variable data components, wherein:
each of a subset of the group of secondary variable data components triggers a subsequent workflow; and the number of secondary variable data components in the subset is fewer than or equal to the number of secondary variable data components in the group.
14. The computing system of claim 13, wherein:
the instruction set comprises instructions to, print the printed variable data component and the group of secondary variable data components; and wherein each secondary variable data component enables a different workflow operation based on a role of the proper user.
15. The computing system of claim 13, wherein instructions to authorize a downstream workflow comprise instructions to trigger a multi-stage workflow wherein each stage of the multi-stage workflow is defined by one of the subset of the group of variable data components.
PCT/US2016/044868 2016-07-29 2016-07-29 Workflow-authorizing computing device authentication WO2018022109A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
PCT/US2016/044868 WO2018022109A1 (en) 2016-07-29 2016-07-29 Workflow-authorizing computing device authentication
CN201680085232.9A CN109416780A (en) 2016-07-29 2016-07-29 The calculating equipment of workflow authorization authenticates
EP16910767.9A EP3446266A4 (en) 2016-07-29 2016-07-29 Workflow-authorizing computing device authentication
US16/097,950 US11030630B2 (en) 2016-07-29 2016-07-29 Workflow-authorizing computing device authentication

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/US2016/044868 WO2018022109A1 (en) 2016-07-29 2016-07-29 Workflow-authorizing computing device authentication

Publications (1)

Publication Number Publication Date
WO2018022109A1 true WO2018022109A1 (en) 2018-02-01

Family

ID=61017117

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2016/044868 WO2018022109A1 (en) 2016-07-29 2016-07-29 Workflow-authorizing computing device authentication

Country Status (4)

Country Link
US (1) US11030630B2 (en)
EP (1) EP3446266A4 (en)
CN (1) CN109416780A (en)
WO (1) WO2018022109A1 (en)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130290963A1 (en) * 2010-12-20 2013-10-31 Hewlett-Packard Development Company, L.P. Workflow-Enhancing Device, System and Method

Family Cites Families (45)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6373965B1 (en) 1994-06-24 2002-04-16 Angstrom Technologies, Inc. Apparatus and methods for authentication using partially fluorescent graphic images and OCR characters
CZ200324A3 (en) * 2000-06-05 2007-01-31 Optaglio Limited Product verification, system for and method of product authentication
US7373515B2 (en) * 2001-10-09 2008-05-13 Wireless Key Identification Systems, Inc. Multi-factor authentication system
US20050028073A1 (en) * 2003-07-28 2005-02-03 Henry Steven G. Method and system for automating workflows
CA2451164C (en) * 2003-09-11 2016-08-30 Teamplate Inc. Customizable components
US7229025B2 (en) 2004-06-07 2007-06-12 Pitney Bowes Inc. Barcode with enhanced additional stored data
JP2006072486A (en) * 2004-08-31 2006-03-16 Konica Minolta Business Technologies Inc Data management device, data management system and data management method
US7350074B2 (en) * 2005-04-20 2008-03-25 Microsoft Corporation Peer-to-peer authentication and authorization
US20060287890A1 (en) * 2005-06-15 2006-12-21 Vanderbilt University Method and apparatus for organizing and integrating structured and non-structured data across heterogeneous systems
US8566598B2 (en) 2005-09-02 2013-10-22 Goodman Consulting Group Method for article authentication using an article's authentication code and a second code provided by the party requesting authentication
US7742762B1 (en) * 2006-11-03 2010-06-22 Sprint Communications Company L.P. Systems and methods for remote notification, diagnostics and remedy management
US8060932B2 (en) * 2006-11-03 2011-11-15 Microsoft Corporation Modular enterprise authorization solution
US7852515B2 (en) 2007-06-05 2010-12-14 Xerox Corporation Infrared encoding for embedding multiple variable data information collocated in printed documents
US20100017223A1 (en) * 2008-03-03 2010-01-21 Amy Johnson Electronic donor medical records management system
JP5178293B2 (en) * 2008-04-15 2013-04-10 キヤノン株式会社 Workflow execution device, workflow execution method, and computer program
US20100106551A1 (en) * 2008-10-24 2010-04-29 Oskari Koskimies Method, system, and apparatus for process management
US8972048B2 (en) 2008-11-20 2015-03-03 Disney Enterprises, Inc. Self-service beverage and snack dispensing using identity-based access control
US8477379B2 (en) * 2009-10-06 2013-07-02 Hewlett-Packard Development Company, L.P. Secure document workflow
CN102236810A (en) * 2010-04-23 2011-11-09 富港电子(昆山)有限公司 QR (Quick Response) code with hidden codes, and formation and identification methods of hidden codes
US9189649B2 (en) * 2010-06-25 2015-11-17 International Business Machines Corporation Security model for workflows aggregating third party secure services
EP2619708A4 (en) * 2010-09-21 2014-04-30 Hewlett Packard Development Co Providing differential access to a digital document
US20120089518A1 (en) * 2010-10-08 2012-04-12 Robert Blonchek Method and system for authenticating prescriptions for controlled substances
EP2447873A1 (en) * 2010-10-27 2012-05-02 Gemalto SA A method and a corresponding device for accessing an application
KR101194531B1 (en) * 2011-05-11 2012-12-24 이창근 Goods selling system and the method of goods selling system for cash rewarding by lottary based on qr cord
US8792141B2 (en) * 2011-06-09 2014-07-29 Xerox Corporation Embedded form extraction definition to enable automatic workflow configuration
US8601276B2 (en) * 2011-07-27 2013-12-03 Hewlett-Packard Development Company, L.P. Managing access to a secure content-part of a PPCD following introduction of the PPCD into a workflow
US9158944B2 (en) * 2011-10-07 2015-10-13 Dynotag, Inc. Systems, methods, and apparatuses for associating flexible internet based information with physical objects
EP2626820A3 (en) * 2012-02-10 2016-10-19 Tata Consultancy Services Limited Role-based content rendering
DE102012203975B4 (en) * 2012-03-14 2018-07-26 Siemens Healthcare Gmbh Computer-implemented method and medical device for automatically starting a workflow
US9406081B2 (en) * 2012-10-26 2016-08-02 Facebook, Inc. Methods and systems for contact importing using a mobile device
US9135427B2 (en) 2013-01-30 2015-09-15 Arris Technology, Inc. Authentication using a subset of a user-known code sequence
US10042979B2 (en) * 2013-03-01 2018-08-07 Airstrip Ip Holdings, Llc Systems and methods for integrating, unifying and displaying patient data across healthcare continua
US20160219039A1 (en) * 2013-09-06 2016-07-28 Mario Houthooft Mobile Authentication Method and System for Providing Authenticated Access to Internet-Sukpported Services and Applications
US9785528B2 (en) 2013-09-18 2017-10-10 Lidong Qu System and method for using data tags to track and manage tasks to provide object-to-object services
US9178889B2 (en) 2013-09-27 2015-11-03 Paypal, Inc. Systems and methods for pairing a credential to a device identifier
US9001370B1 (en) * 2013-11-15 2015-04-07 Ricoh Company, Ltd. Card authentication for OAuth supported cloud services on a multi-function device
EP3090111A4 (en) * 2014-01-03 2017-09-06 ADC Telecommunications Inc. Remote electronic physical layer access control using an automated infrastructure management system
US9344419B2 (en) * 2014-02-27 2016-05-17 K.Y. Trix Ltd. Methods of authenticating users to a site
US20150286802A1 (en) * 2014-04-07 2015-10-08 Himanshu Kansara System and method for clinical trial management
JP5914579B2 (en) * 2014-06-16 2016-05-11 株式会社トッパンTdkレーベル Concealment target information concealment method, concealment target information concealment device, program, concealment target information extraction method, and concealment target information extraction device
US11107574B2 (en) * 2014-09-30 2021-08-31 Baxter Corporation Englewood Management of medication preparation with formulary management
US20170317830A1 (en) * 2014-10-30 2017-11-02 Hewlett-Packard Development Company, L.P. Access Medium
CN204360383U (en) * 2014-12-19 2015-05-27 福建新大陆电脑股份有限公司 A kind of bar code recognizing apparatus of high pixel image processing
US10346590B2 (en) * 2015-08-21 2019-07-09 Scriptpro Llc Prescription storage and retrieval system
US10164975B1 (en) * 2016-03-30 2018-12-25 Snap Inc. Authentication via camera

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130290963A1 (en) * 2010-12-20 2013-10-31 Hewlett-Packard Development Company, L.P. Workflow-Enhancing Device, System and Method

Also Published As

Publication number Publication date
US20190147458A1 (en) 2019-05-16
US11030630B2 (en) 2021-06-08
CN109416780A (en) 2019-03-01
EP3446266A4 (en) 2020-01-22
EP3446266A1 (en) 2019-02-27

Similar Documents

Publication Publication Date Title
US10320807B2 (en) Systems and methods relating to the authenticity and verification of photographic identity documents
US8881251B1 (en) Electronic authentication using pictures and images
EP2885904B1 (en) User-convenient authentication method and apparatus using a mobile authentication application
US20160210621A1 (en) Verifiable credentials and methods thereof
US10115243B2 (en) Near field communication system
US8224293B1 (en) Encoded colorgram for mobile device security
US20110113245A1 (en) One time pin generation
US20120278241A1 (en) Traceable and non-reputable transaction devices and methods
WO2015028772A1 (en) Data encryption and smartcard storing encrypted data
WO2014008228A1 (en) Credential quality assessment engine systems and methods
TWI566564B (en) Virtual reality authentication circuit, system and electronic consumption method
KR20060132763A (en) Authentication system by using bar-code which otp-code added, and its method
US20200106771A1 (en) Systems and methods for authenticating users within a computing or access control environment
WO2014072725A1 (en) Mobile tag reader security system
US20140331302A1 (en) Method for securing an electronic document
US20190158493A1 (en) Triggering role-based workflows with user authentication
US11688153B2 (en) Object ID-centered workflow
US20160087971A1 (en) Method And System For Generating Identification And Certification Of E-License
WO2017171698A1 (en) Payment authentication
US20130090059A1 (en) Identity verification
Singhal Security analysis of aadhaar authentication process and way forward
US11030630B2 (en) Workflow-authorizing computing device authentication
US20160342996A1 (en) Two-factor authentication method
WO2016013924A1 (en) System and method of mutual authentication using barcode
Patil et al. Design and implementation of secure biometric based authentication system using rfid and secret sharing

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 2016910767

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2016910767

Country of ref document: EP

Effective date: 20181030

NENP Non-entry into the national phase

Ref country code: DE