US20200242585A1 - Processing payments for an online marketplace - Google Patents
Processing payments for an online marketplace Download PDFInfo
- Publication number
- US20200242585A1 US20200242585A1 US16/846,802 US202016846802A US2020242585A1 US 20200242585 A1 US20200242585 A1 US 20200242585A1 US 202016846802 A US202016846802 A US 202016846802A US 2020242585 A1 US2020242585 A1 US 2020242585A1
- Authority
- US
- United States
- Prior art keywords
- code
- transaction
- updated
- machine readable
- readable code
- Prior art date
- Legal status (The legal status 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 status listed.)
- Pending
Links
- 238000012545 processing Methods 0.000 title abstract description 13
- 238000000034 method Methods 0.000 claims abstract description 34
- 230000015654 memory Effects 0.000 claims description 22
- 230000004044 response Effects 0.000 claims description 14
- 239000011159 matrix material Substances 0.000 claims description 5
- 230000008569 process Effects 0.000 claims description 5
- 238000003860 storage Methods 0.000 abstract description 25
- 238000013459 approach Methods 0.000 abstract description 11
- 238000004519 manufacturing process Methods 0.000 abstract description 2
- 230000006870 function Effects 0.000 description 9
- 238000004891 communication Methods 0.000 description 7
- 238000012546 transfer Methods 0.000 description 6
- 230000003993 interaction Effects 0.000 description 5
- 238000012790 confirmation Methods 0.000 description 4
- 238000013461 design Methods 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 230000000007 visual effect Effects 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 2
- 101150110972 ME1 gene Proteins 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 230000001276 controlling effect Effects 0.000 description 1
- 230000002596 correlated effect Effects 0.000 description 1
- 230000000875 corresponding effect Effects 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 238000009826 distribution Methods 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 239000005022 packaging material Substances 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 239000011253 protective coating Substances 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 230000005236 sound signal Effects 0.000 description 1
- 230000001755 vocal effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION 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
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/30—Payment architectures, schemes or protocols characterised by the use of specific devices or networks
- G06Q20/32—Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices
- G06Q20/327—Short range or proximity payments by means of M-devices
- G06Q20/3274—Short range or proximity payments by means of M-devices using a pictured code, e.g. barcode or QR-code, being displayed on the M-device
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION 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
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/08—Payment architectures
- G06Q20/10—Payment architectures specially adapted for electronic funds transfer [EFT] systems; specially adapted for home banking systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION 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
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/08—Payment architectures
- G06Q20/20—Point-of-sale [POS] network systems
- G06Q20/204—Point-of-sale [POS] network systems comprising interface for record bearing medium or carrier for electronic funds transfer or payment credit
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION 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
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/40—Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
- G06Q20/401—Transaction verification
Definitions
- the present disclosure relates to processing transactions and more specifically to enabling users to complete transactions for an online marketplace using a mobile device without purchasing a physical gift card or other physical object at a point of sale.
- Users can add funds to their accounts for such online marketplaces in a number of ways. For example, many device owners add funds directly on the device via an associated credit or debit account. However, many users either can not or choose not to register a credit or debit account with the online marketplace. Such users can include children or teenagers, users in countries where such accounts are not widely accepted, or users who are simply leery of sharing their credit or debit account information.
- FIG. 1 illustrates an example transaction environment
- FIG. 2 illustrates an example enrollment interaction between a user and an online marketplace server
- FIG. 3 illustrates an example purchase interaction in the example transaction environment
- FIG. 4 illustrates an example user interface on a mobile device
- FIG. 5 illustrates an example method embodiment for enrolling a user
- FIG. 6 illustrates an example method embodiment for processing a transaction from the standpoint of a merchant
- FIG. 7 illustrates an example method embodiment for processing a transaction from the standpoint of an online marketplace server
- FIG. 8 illustrates an example system embodiment.
- the user presents to a point of sale device, a machine-readable code, such as a barcode rendered on a display of his or her mobile device.
- the point of sale device can scan the machine-readable code, and use existing transaction processing infrastructure for processing physical cards for payment to transmit a serial number to the online marketplace to initiate the transaction.
- Users do not need to purchase a plastic card from a merchant, and instead only present their mobile device, such as smartphone or tablet, to be scanned at the point of sale. Further, this approach can enhance customer convenience because customers do not have to scratch off a card, and enter a lengthy serial number.
- This approach can also reduce customer support costs due to events such as physical card scratch off code problems or lost or stolen cards. Further, this approach can enhance customer convenience because customers do not have to scratch off a protective coating on the card to reveal the redemption code and subsequently enter a lengthy redemption code at the online marketplace. Users can then load funds into their accounts with the online marketplace from any merchant location that is a reseller for the online marketplace.
- FIG. 1 illustrates an example transaction environment 100 .
- a user 102 presents, via a mobile device 104 , a unique pass with a barcode to be scanned at point of sale 106 .
- the retailer at the point of sale 106 scans the unique pass, such as via an optical scanner.
- the mobile device 104 can alternatively present the unique pass to the retailer via near-field communications (NFC) or some other communication medium.
- NFC near-field communications
- the unique pass can be encoded for display on a screen such as via a linear barcode, a two-dimensional or matrix bar code, or a scannable image or text.
- the user 102 decides how much money to add to his or her account with the online marketplace, and provides payment for that amount at the point of sale 106 via a cash, check, credit or debit card, or other payment transaction.
- the point of sale 106 device communicates, via a payment network 110 , with an online marketplace server 108 to complete the transaction. When the transaction is complete, the funds are available immediately for use in the account of the user 102 , for purchases via the mobile device 104 .
- the user 102 can present an iPhone as the mobile device 104 with a barcode rendered on the display, such as in an app that manages various coupons, tickets, loyalty cards, and other secure documents or barcodes.
- the retailer scans the barcode presented on the user's iPhone at the point of sale 106 .
- the user 102 asks the merchant to load $40.00 on her iTunes account and tenders $40.00 as payment.
- the user can tender the $40.00 using any payment means available at the point of sale, including cash.
- the merchant accesses the online marketplace server 108 via existing hardware and software payment infrastructure using a serial number identified from the barcode to load the $40.00 onto the user's iTunes account.
- the online marketplace server 108 updates the user's account balance, making the funds available for immediate use.
- the online marketplace server 108 can provide an indication of success to the point of sale 106 and can also send a notification to the user's iPhone. This approach can open a new distribution channel for loading funds onto accounts with the online marketplace server 108 without the cost and complexities of a physical card.
- FIG. 2 illustrates an example enrollment interaction 200 between a user and an online marketplace server that occurs prior to a payment transaction.
- the user 102 can open an enrollment app or an enrollment dialog of an app on a smartphone or other mobile device 104 .
- the mobile device 104 provides account details 202 to the online marketplace server 108 .
- the account details can include a username, password, unique identifier of the device 104 , a unique account identifier, or some other information.
- the account details can be transmitted via or after challenge-response authentication.
- the online marketplace server 108 can assign a marketplace serial number 204 to an account indicated by the account details 202 , and transmit that serial number 204 to the mobile device 104 .
- the online marketplace server 108 can store this serial number 204 and account pair in a database.
- the serial number may be the same as the unique account identifier, but in some embodiments the serial number is completely different, and is only correlated to the account in a database accessible to the online marketplace server 108 . Without this database, the serial number would be meaningless and would not contain or represent any useful information.
- the mobile device 104 uses the serial number 204 to generate a barcode encoding the serial number 206 .
- the mobile device 104 can generate the barcode upon receiving the serial number 206 , or can receive and store the serial number 206 and generate the barcode 206 on-demand.
- the mobile device 104 can encode the serial number in different types of barcodes for different types of scanning equipment or for different merchant scenarios.
- the mobile device 104 can generate the barcode with an embedded timestamp which limits the barcode to being used within a specific period of time.
- the online marketplace server 108 can alternatively encode the serial number 204 in a barcode and transmit the barcode to the mobile device 104 .
- the mobile device 104 does not generate the barcode, but simply stores the image of the barcode and displays the barcode upon request from the user 102 .
- FIG. 3 illustrates an example purchase interaction 300 in the example transaction environment 100 .
- the user causes the mobile device 104 to render a barcode 302 on the display and presents the barcode 302 to the point of sale 106 for scanning.
- the merchant enters an amount 304 to load onto the user's account.
- the user provides payment of the amount 306 .
- the point of sale 106 submits transaction details 308 to the online marketplace server 108 via the existing payment network 110 infrastructure.
- the transaction details can include an amount, a serial number extracted from the barcode 302 , a payment method, a timestamp, a device identifier, a device type, or any other information gathered by the merchant or encoded in the barcode 302 .
- the online marketplace server 108 can optionally send a confirmation 310 to the point of sale 106 .
- the online marketplace server 108 can also optionally push a notification to the mobile device 104 that the funds have been loaded.
- the notification can be an email or text message, or can be a notification pushed via a network to a specific app or to the operating system of the mobile device 104 .
- the notification can be stored in the online marketplace, so the user receives the notification the next time he or she opens the online marketplace portal on the mobile device 104 or at any other location, such as a desktop computer.
- the online marketplace server 108 can modify the barcode or the serial number, such as incrementing a counter in the barcode or incrementing a counter in a portion of the serial number, and transmit an updated barcode or an updated serial number to the mobile device 104 (or to multiple registered mobile devices).
- FIG. 4 illustrates an example user interface 400 on the mobile device 104 .
- This example user interface 400 includes a name 402 of the account, the barcode 404 , and an account balance 406 .
- the name 402 allows the user to quickly determine that the barcode is for the desired account.
- the user interface 400 can include a barcode 404 such as a QR code, a linear barcode, or some other barcode.
- the user interface 400 can include multiple barcodes, or can allow the user to swipe back and forth between different barcodes or otherwise select one of a set of barcodes.
- the device can determine, based on location data, to which retailer the device is likely being presented for scanning, and automatically select a barcode type to display for known capabilities of scanning equipment at that retailer location.
- the account balance 406 can update dynamically to reflect purchases in the online marketplace as well as funds loaded onto the account. Because the barcode does not typically encode the account balance, an updated account balance 406 would not necessarily lead to a change in the barcode.
- the mobile device 104 can provide location data via the barcode. Then the online marketplace server 108 can perform additional authentication based on the location data. An app on the mobile device 104 can further incorporate account authentication when generating the barcode.
- the online marketplace server 108 can manage push notifications, comparing and authenticating mobile devices based on location data, tracking account balances, encoding data into barcodes, incorporating digital signatures into barcodes, and so forth.
- the mobile device 104 can have different software plugins or modules for generating different types of barcodes.
- an app can rely on the same underlying logic, while providing a different barcode for different regions. For example, if QR codes are more popular with retailers in Japan, the app can use or retrieve a module for generating QR codes based on location when in Japan. Similarly, when in Canada, the app can determine that linear UPC barcodes are more popular and can retrieve and use a module for generating linear UPC barcodes. This approach can further apply to individual merchants, so that the app renders a barcode or other machine-readable code for a specific retailer, when the location data of the mobile device 104 indicates that the user is at the specific retailer.
- the mobile device 104 can provide instructions for how to load funds onto the account with the online marketplace, especially for users who have not loaded funds before, or who do not already have an associated payment account.
- the mobile device 104 or the online marketplace can provide these instructions when the account balance is below a threshold, or when the user is within a threshold distance from a location that can load funds onto the account by scanning a barcode.
- the mobile device 104 can incorporate a location based alert to wake the mobile phone 104 up when within the threshold distance, and automatically display the barcode, whether by opening an app or by temporarily changing a wallpaper of the mobile device lock screen, for example.
- the mobile device 104 can determine location data based on GPS signals and latitude and longitude coordinates. The mobile device 104 or the online marketplace server 108 can then compare the coordinates to a database of known merchants and point of sale locations. Alternatively, a merchant can install a Wi-Fi transmitter or other wireless device that provides an identifier to the mobile device 104 indicating a location of the mobile device. This approach can be helpful for mobile devices that are not always connected or do not have GPS hardware, such as portable music players or tablets. For example, a merchant can install a BluetoothTM puck that broadcasts location data or a location identifier that the mobile device 104 can use when generating a barcode to be scanned for a transaction with the online marketplace server 108 .
- FIGS. 5-7 For the sake of clarity, each of the methods is described in terms of an exemplary system 800 as shown in FIG. 8 configured to practice the respective method.
- the steps outlined herein are exemplary and can be implemented in any combination thereof, including combinations that exclude, reorder, add, or modify certain steps.
- FIG. 5 illustrates an example method embodiment for enrolling a user.
- the system receives, from a user device and at an authentication server of an online marketplace, an enrollment request, wherein the enrollment request identifies a user account with the online marketplace, the user account existing prior to the enrollment request ( 502 ).
- An app for managing bar codes from multiple sources on the user device can generate and transmit the enrollment request.
- the system can further receive, from the user device and at the authentication server of an online marketplace, additional account details as part of the enrollment request, and confirm the additional account details as part of an authentication routine.
- the system can associate a serial number with the user account ( 504 ).
- the system can determine that an existing serial number has been associated with the user account prior to the enrollment request, and transmit the existing serial number to the user device instead of generating an entirely new serial number.
- a single serial number is used for all devices associated with the user account, while in another aspect, each device associated with the user account is associated with a different serial number.
- One user account can be associated with multiple serial numbers either in series or at the same time.
- the system can transmit the serial number to the user device for identifying the user account at a point of sale terminal ( 506 ).
- the system can transmit the serial number in plain text, as an encrypted message, encoded in an image of a machine-readable code, or as instructions for generating a machine-readable code.
- the machine-readable code can be an image for rendering on a display, or the machine readable code can be a specially formed text or image string.
- the machine-readable code can also include non-visual codes, such as an audio signal or a wireless transmission such as communication via NFC devices.
- FIG. 6 illustrates an example method embodiment for processing a transaction from the standpoint of a merchant.
- the system can scan a machine-readable code presented on a display of a mobile device ( 602 ).
- the machine-readable code can be a quick response (QR) code, a linear barcode, a two dimensional barcode, or a matrix barcode, for example.
- the mobile device can present other types of visual and/or non-visual machine-readable codes.
- the system can identify, from the machine-readable code, a serial number associated with a user account of an online marketplace ( 604 ).
- the system can receive payment of an amount of money ( 606 ).
- the system can prompt a store clerk to enter the amount of money.
- the user can provide verbal instructions regarding the amount of money or can enter the amount on a keypad on the point of sale equipment, or via the mobile device itself.
- the system can transmit to the online marketplace the serial number and an indication of the amount of money as part of a payment transaction for applying the amount of money to the user account ( 608 ).
- the system can further identify, from the machine-readable code, location data of the mobile device, and transmit the location data to the online marketplace.
- the system can receive a confirmation of the payment transaction ( 610 ).
- the system receives, from the online marketplace, a balance of the user account, and determines a top-up amount based on the balance. Then the system can suggest the top-up amount as the amount of money to load onto the account. For example, the system can determine an amount that is greater than $20.00 that, if added to the balance, would total the next even multiple of $5.00.
- the system can suggest a top-up amount of $21.71 to reach a total of $35.00.
- the exact rules for suggesting top-up amounts may vary, and can be user-configurable. If the user does not configure settings for making top-up amount recommendations, the system can apply system defaults. Further, the user can enable or disable such top-up recommendations altogether.
- FIG. 7 illustrates an example method embodiment for processing a transaction from the standpoint of an online marketplace server.
- the system can receive, from a point of sale device and as part of a request to process a payment transaction, a serial number and an indication of an amount of money, wherein the serial number was obtained by scanning a machine-readable code presented on a display of a mobile device ( 702 ).
- the online marketplace provided the machine-readable code to the mobile device.
- the system can identify, based on the serial number, a user account of an online marketplace ( 704 ).
- the serial number can be associated with a user account of the mobile device, or with a second user account other than the user account with which the serial number is associated.
- the system can receive an indication of an amount of credit to transfer from the second user account to the user account, and transfer the amount of credit from the second user account to the user account. This can enable a user to transfer credit between accounts, such as a parent managing credit among children's accounts, or such as a friend giving a gift.
- the barcode can encode additional information such as a message or electronic card from the giver to the recipient.
- the additional information can include instructions to the online marketplace server 108 for how or when to deliver the transfer of credit.
- this additional information can be gathered via an app on the mobile device 104 and transmitted separately to the online marketplace server 108 with an identifier for matching up the additional information with a specific transaction. Then the online marketplace server 108 can match the message with the transaction, and push a notification to a mobile device of the recipient, including at least part of the additional message.
- the system can receive from the point of sale device a payment associated with the payment transaction ( 706 ) and apply the amount of money to the user account of the online marketplace ( 708 ).
- the system can transmit, to the point of sale device, a confirmation of the payment transaction ( 710 ).
- the system can also push a notification to the mobile device of the confirmation of the payment transaction.
- the notification can be a pop-up or email, for example.
- the system pushes a notification to the mobile device that simply updates the balance 406 , such as in the example user interface 400 of FIG. 4 . In this way, the user can simply watch the user interface 400 and confirm that the transaction was successful simply based on the updated balance 406 .
- the system can receive, at a mobile device, a request to initiate a payment transaction for a user account with an online marketplace.
- the system can retrieve, from a memory of the mobile device, a serial number associated with the user account.
- system can generate a machine-readable code storing the serial number.
- the system can present, on a display of the mobile device, the machine-readable code to be scanned by a point of sale device as part of the payment transaction.
- the machine-readable code can encode additional data including at least one of location data, user account data, credentials, an amount associated with the payment transaction, a timestamp, or a personal identification number (PIN).
- PIN personal identification number
- the serial number can be associated with the user account during an enrollment process prior to the request to initiate the payment transaction.
- an exemplary system and/or computing device 800 includes a processing unit (CPU or processor) 820 and a system bus 810 that couples various system components including the system memory 830 such as read only memory (ROM) 840 and random access memory (RAM) 850 to the processor 820 .
- the system 800 can include a cache 822 of high-speed memory connected directly with, in close proximity to, or integrated as part of the processor 820 .
- the system 800 copies data from the memory 830 and/or the storage device 860 to the cache 822 for quick access by the processor 820 .
- the cache provides a performance boost that avoids processor 820 delays while waiting for data.
- These and other modules can control or be configured to control the processor 820 to perform various operations or actions.
- Other system memory 830 may be available for use as well.
- the memory 830 can include multiple different types of memory with different performance characteristics. It can be appreciated that the disclosure may operate on a computing device 800 with more than one processor 820 or on a group or cluster of computing devices networked together to provide greater processing capability.
- the processor 820 can include any general purpose processor and a hardware module or software module, such as module 1 862 , module 2 864 , and module 3 866 stored in storage device 860 , configured to control the processor 820 as well as a special-purpose processor where software instructions are incorporated into the processor.
- the processor 820 may be a self-contained computing system, containing multiple cores or processors, a bus, memory controller, cache, etc.
- a multi-core processor may be symmetric or asymmetric.
- the processor 820 can include multiple processors, such as a system having multiple, physically separate processors in different sockets, or a system having multiple processor cores on a single physical chip.
- the processor 820 can include multiple distributed processors located in multiple separate computing devices, but working together such as via a communications network. Multiple processors or processor cores can share resources such as memory 830 or the cache 822 , or can operate using independent resources.
- the processor 820 can include one or more of a state machine, an application specific integrated circuit (ASIC), or a programmable gate array (PGA) including a field PGA.
- ASIC application specific integrated circuit
- PGA programmable gate array
- the system bus 810 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures.
- a basic input/output (BIOS) stored in ROM 840 or the like, may provide the basic routine that helps to transfer information between elements within the computing device 800 , such as during start-up.
- the computing device 800 further includes storage devices 860 or computer-readable storage media such as a hard disk drive, a magnetic disk drive, an optical disk drive, tape drive, solid-state drive, RAM drive, removable storage devices, a redundant array of inexpensive disks (RAID), hybrid storage device, or the like.
- the storage device 860 can include software modules 862 , 864 , 866 for controlling the processor 820 .
- the system 800 can include other hardware or software modules.
- the storage device 860 is connected to the system bus 810 by a drive interface.
- the drives and the associated computer-readable storage devices provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for the computing device 800 .
- a hardware module that performs a particular function includes the software component stored in a tangible computer-readable storage device in connection with the necessary hardware components, such as the processor 820 , bus 810 , display 870 , and so forth, to carry out a particular function.
- the system can use a processor and computer-readable storage device to store instructions which, when executed by the processor, cause the processor to perform operations, a method or other specific actions.
- the basic components and appropriate variations can be modified depending on the type of device, such as whether the device 800 is a small, handheld computing device, a desktop computer, or a computer server.
- the processor 820 executes instructions to perform “operations”, the processor 820 can perform the operations directly and/or facilitate, direct, or cooperate with another device or component to perform the operations.
- exemplary embodiment(s) described herein employs the hard disk 860
- other types of computer-readable storage devices which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, digital versatile disks (DVDs), cartridges, random access memories (RAMs) 850 , read only memory (ROM) 840 , a cable containing a bit stream and the like, may also be used in the exemplary operating environment.
- Tangible computer-readable storage media, computer-readable storage devices, or computer-readable memory devices expressly exclude media such as transitory waves, energy, carrier signals, electromagnetic waves, and signals per se.
- an input device 890 represents any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth.
- An output device 870 can also be one or more of a number of output mechanisms known to those of skill in the art.
- multimodal systems enable a user to provide multiple types of input to communicate with the computing device 800 .
- the communications interface 880 generally governs and manages the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic hardware depicted may easily be substituted for improved hardware or firmware arrangements as they are developed.
- the illustrative system embodiment is presented as including individual functional blocks including functional blocks labeled as a “processor” or processor 820 .
- the functions these blocks represent may be provided through the use of either shared or dedicated hardware, including, but not limited to, hardware capable of executing software and hardware, such as a processor 820 , that is purpose-built to operate as an equivalent to software executing on a general purpose processor.
- a processor 820 that is purpose-built to operate as an equivalent to software executing on a general purpose processor.
- the functions of one or more processors presented in FIG. 8 may be provided by a single shared processor or multiple processors.
- Illustrative embodiments may include microprocessor and/or digital signal processor (DSP) hardware, read-only memory (ROM) 840 for storing software performing the operations described below, and random access memory (RAM) 850 for storing results.
- DSP digital signal processor
- ROM read-only memory
- RAM random access memory
- VLSI Very large scale integration
- the logical operations of the various embodiments are implemented as: (1) a sequence of computer implemented steps, operations, or procedures running on a programmable circuit within a general use computer, (2) a sequence of computer implemented steps, operations, or procedures running on a specific-use programmable circuit; and/or (3) interconnected machine modules or program engines within the programmable circuits.
- the system 800 shown in FIG. 8 can practice all or part of the recited methods, can be a part of the recited systems, and/or can operate according to instructions in the recited tangible computer-readable storage devices.
- Such logical operations can be implemented as modules configured to control the processor 820 to perform particular functions according to the programming of the module. For example, FIG.
- Mod1 862 illustrates three modules Mod1 862 , Mod2 864 and Mod3 866 which are modules configured to control the processor 820 . These modules may be stored on the storage device 860 and loaded into RAM 850 or memory 830 at runtime or may be stored in other computer-readable memory locations.
- a virtual processor can be a software object that executes according to a particular instruction set, even when a physical processor of the same type as the virtual processor is unavailable.
- a virtualization layer or a virtual “host” can enable virtualized components of one or more different computing devices or device types by translating virtualized operations to actual operations.
- virtualized hardware of every type is implemented or executed by some underlying physical hardware.
- a virtualization compute layer can operate on top of a physical compute layer.
- the virtualization compute layer can include one or more of a virtual machine, an overlay network, a hypervisor, virtual switching, and any other virtualization application.
- the processor 820 can include all types of processors disclosed herein, including a virtual processor. However, when referring to a virtual processor, the processor 820 includes the software components associated with executing the virtual processor in a virtualization layer and underlying hardware necessary to execute the virtualization layer.
- the system 800 can include a physical or virtual processor 820 that receive instructions stored in a computer-readable storage device, which cause the processor 820 to perform certain operations. When referring to a virtual processor 820 , the system also includes the underlying physical hardware executing the virtual processor 820 .
- Embodiments within the scope of the present disclosure may also include tangible and/or non-transitory computer-readable storage devices for carrying or having computer-executable instructions or data structures stored thereon.
- Such tangible computer-readable storage devices can be any available device that can be accessed by a general purpose or special purpose computer, including the functional design of any special purpose processor as described above.
- such tangible computer-readable devices can include RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other device which can be used to carry or store desired program code in the form of computer-executable instructions, data structures, or processor chip design.
- Computer-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions.
- Computer-executable instructions also include program modules that are executed by computers in stand-alone or network environments.
- program modules include routines, programs, components, data structures, objects, and the functions inherent in the design of special-purpose processors, etc. that perform particular tasks or implement particular abstract data types.
- Computer-executable instructions, associated data structures, and program modules represent examples of the program code means for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps.
- Embodiments of the disclosure may be practiced in network computing environments with many types of computer system configurations, including personal computers, hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. Embodiments may also be practiced in distributed computing environments where tasks are performed by local and remote processing devices that are linked (either by hardwired links, wireless links, or by a combination thereof) through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
Landscapes
- Business, Economics & Management (AREA)
- Accounting & Taxation (AREA)
- Engineering & Computer Science (AREA)
- Finance (AREA)
- Physics & Mathematics (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Economics (AREA)
- Development Economics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Computer Security & Cryptography (AREA)
- Cash Registers Or Receiving Machines (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Abstract
Description
- This application is a Continuation of U.S. application Ser. No. 14/195,773, filed on Mar. 3, 2014, the content of which is incorporated herein by reference in its entirety.
- The present disclosure relates to processing transactions and more specifically to enabling users to complete transactions for an online marketplace using a mobile device without purchasing a physical gift card or other physical object at a point of sale.
- The majority of mobile operating systems, and an increasing number of non-mobile operating systems, provide access to an online marketplace for users to purchase music, movies, software, upgrades, in-app content, and so forth. Users can add funds to their accounts for such online marketplaces in a number of ways. For example, many device owners add funds directly on the device via an associated credit or debit account. However, many users either can not or choose not to register a credit or debit account with the online marketplace. Such users can include children or teenagers, users in countries where such accounts are not widely accepted, or users who are simply leery of sharing their credit or debit account information.
- These users can go to a store, purchase a gift card for the online marketplace using the payment method of their choice, and use that gift card to load funds on the account with the online marketplace. However, this approach has several disadvantages. For example, the entity operating the online marketplace must manufacture, track, and distribute physical items, such as plastic cards. These all have associated managerial and financial costs. Further, merchants must keep these physical items in stock to make sales, which occupies valuable shelf space, often at prime retail locations near the check-out counters. This approach also wastes a large amount of plastic and other shipping and packaging materials.
-
FIG. 1 illustrates an example transaction environment; -
FIG. 2 illustrates an example enrollment interaction between a user and an online marketplace server; -
FIG. 3 illustrates an example purchase interaction in the example transaction environment; -
FIG. 4 illustrates an example user interface on a mobile device; -
FIG. 5 illustrates an example method embodiment for enrolling a user; -
FIG. 6 illustrates an example method embodiment for processing a transaction from the standpoint of a merchant; -
FIG. 7 illustrates an example method embodiment for processing a transaction from the standpoint of an online marketplace server; and -
FIG. 8 illustrates an example system embodiment. - Disclosed herein are systems and methods for allowing a user to load funds onto an account with an online marketplace without purchasing a physical item. The user presents to a point of sale device, a machine-readable code, such as a barcode rendered on a display of his or her mobile device. The point of sale device can scan the machine-readable code, and use existing transaction processing infrastructure for processing physical cards for payment to transmit a serial number to the online marketplace to initiate the transaction. Users do not need to purchase a plastic card from a merchant, and instead only present their mobile device, such as smartphone or tablet, to be scanned at the point of sale. Further, this approach can enhance customer convenience because customers do not have to scratch off a card, and enter a lengthy serial number. This approach can also reduce customer support costs due to events such as physical card scratch off code problems or lost or stolen cards. Further, this approach can enhance customer convenience because customers do not have to scratch off a protective coating on the card to reveal the redemption code and subsequently enter a lengthy redemption code at the online marketplace. Users can then load funds into their accounts with the online marketplace from any merchant location that is a reseller for the online marketplace.
- Various embodiments of the disclosure are described in detail below. While specific implementations are described, it should be understood that this is done for illustration purposes only. Other components and configurations may be used without parting from the spirit and scope of the disclosure.
-
FIG. 1 illustrates anexample transaction environment 100. In thisenvironment 100, auser 102 presents, via amobile device 104, a unique pass with a barcode to be scanned at point ofsale 106. The retailer at the point ofsale 106 scans the unique pass, such as via an optical scanner. Themobile device 104 can alternatively present the unique pass to the retailer via near-field communications (NFC) or some other communication medium. The unique pass can be encoded for display on a screen such as via a linear barcode, a two-dimensional or matrix bar code, or a scannable image or text. Theuser 102 decides how much money to add to his or her account with the online marketplace, and provides payment for that amount at the point ofsale 106 via a cash, check, credit or debit card, or other payment transaction. The point ofsale 106 device communicates, via apayment network 110, with anonline marketplace server 108 to complete the transaction. When the transaction is complete, the funds are available immediately for use in the account of theuser 102, for purchases via themobile device 104. - For example, the
user 102 can present an iPhone as themobile device 104 with a barcode rendered on the display, such as in an app that manages various coupons, tickets, loyalty cards, and other secure documents or barcodes. The retailer scans the barcode presented on the user's iPhone at the point ofsale 106. Theuser 102 asks the merchant to load $40.00 on her iTunes account and tenders $40.00 as payment. The user can tender the $40.00 using any payment means available at the point of sale, including cash. The merchant accesses theonline marketplace server 108 via existing hardware and software payment infrastructure using a serial number identified from the barcode to load the $40.00 onto the user's iTunes account. Theonline marketplace server 108 updates the user's account balance, making the funds available for immediate use. Theonline marketplace server 108 can provide an indication of success to the point ofsale 106 and can also send a notification to the user's iPhone. This approach can open a new distribution channel for loading funds onto accounts with theonline marketplace server 108 without the cost and complexities of a physical card. - In one variation, the
user 102 enrolls prior to using this payment approach.FIG. 2 illustrates anexample enrollment interaction 200 between a user and an online marketplace server that occurs prior to a payment transaction. Theuser 102 can open an enrollment app or an enrollment dialog of an app on a smartphone or othermobile device 104. Themobile device 104 providesaccount details 202 to theonline marketplace server 108. The account details can include a username, password, unique identifier of thedevice 104, a unique account identifier, or some other information. The account details can be transmitted via or after challenge-response authentication. Theonline marketplace server 108 can assign amarketplace serial number 204 to an account indicated by theaccount details 202, and transmit thatserial number 204 to themobile device 104. Theonline marketplace server 108 can store thisserial number 204 and account pair in a database. The serial number may be the same as the unique account identifier, but in some embodiments the serial number is completely different, and is only correlated to the account in a database accessible to theonline marketplace server 108. Without this database, the serial number would be meaningless and would not contain or represent any useful information. - In one variation, the
mobile device 104 uses theserial number 204 to generate a barcode encoding theserial number 206. Themobile device 104 can generate the barcode upon receiving theserial number 206, or can receive and store theserial number 206 and generate thebarcode 206 on-demand. For example, themobile device 104 can encode the serial number in different types of barcodes for different types of scanning equipment or for different merchant scenarios. Themobile device 104 can generate the barcode with an embedded timestamp which limits the barcode to being used within a specific period of time. - The
online marketplace server 108 can alternatively encode theserial number 204 in a barcode and transmit the barcode to themobile device 104. In this approach, themobile device 104 does not generate the barcode, but simply stores the image of the barcode and displays the barcode upon request from theuser 102. -
FIG. 3 illustrates anexample purchase interaction 300 in theexample transaction environment 100. Atstep 1, the user causes themobile device 104 to render abarcode 302 on the display and presents thebarcode 302 to the point ofsale 106 for scanning. Atstep 2, the merchant enters anamount 304 to load onto the user's account. Atstep 3, the user provides payment of theamount 306. Atstep 4, the point ofsale 106 submits transaction details 308 to theonline marketplace server 108 via the existingpayment network 110 infrastructure. The transaction details can include an amount, a serial number extracted from thebarcode 302, a payment method, a timestamp, a device identifier, a device type, or any other information gathered by the merchant or encoded in thebarcode 302. Theonline marketplace server 108 can optionally send aconfirmation 310 to the point ofsale 106. Theonline marketplace server 108 can also optionally push a notification to themobile device 104 that the funds have been loaded. The notification can be an email or text message, or can be a notification pushed via a network to a specific app or to the operating system of themobile device 104. The notification can be stored in the online marketplace, so the user receives the notification the next time he or she opens the online marketplace portal on themobile device 104 or at any other location, such as a desktop computer. - In one variation, when the
user 102 uses the barcode to load funds onto his or her account, the barcode remains the same. In another variation, when theuser 102 uses the barcode to load funds onto his or her account, theonline marketplace server 108 can modify the barcode or the serial number, such as incrementing a counter in the barcode or incrementing a counter in a portion of the serial number, and transmit an updated barcode or an updated serial number to the mobile device 104 (or to multiple registered mobile devices). -
FIG. 4 illustrates anexample user interface 400 on themobile device 104. Thisexample user interface 400 includes aname 402 of the account, thebarcode 404, and anaccount balance 406. Thename 402 allows the user to quickly determine that the barcode is for the desired account. Theuser interface 400 can include abarcode 404 such as a QR code, a linear barcode, or some other barcode. Theuser interface 400 can include multiple barcodes, or can allow the user to swipe back and forth between different barcodes or otherwise select one of a set of barcodes. Alternatively, the device can determine, based on location data, to which retailer the device is likely being presented for scanning, and automatically select a barcode type to display for known capabilities of scanning equipment at that retailer location. Theaccount balance 406 can update dynamically to reflect purchases in the online marketplace as well as funds loaded onto the account. Because the barcode does not typically encode the account balance, an updatedaccount balance 406 would not necessarily lead to a change in the barcode. - The
mobile device 104 can provide location data via the barcode. Then theonline marketplace server 108 can perform additional authentication based on the location data. An app on themobile device 104 can further incorporate account authentication when generating the barcode. Theonline marketplace server 108 can manage push notifications, comparing and authenticating mobile devices based on location data, tracking account balances, encoding data into barcodes, incorporating digital signatures into barcodes, and so forth. - The
mobile device 104 can have different software plugins or modules for generating different types of barcodes. For example, an app can rely on the same underlying logic, while providing a different barcode for different regions. For example, if QR codes are more popular with retailers in Japan, the app can use or retrieve a module for generating QR codes based on location when in Japan. Similarly, when in Canada, the app can determine that linear UPC barcodes are more popular and can retrieve and use a module for generating linear UPC barcodes. This approach can further apply to individual merchants, so that the app renders a barcode or other machine-readable code for a specific retailer, when the location data of themobile device 104 indicates that the user is at the specific retailer. - The
mobile device 104 can provide instructions for how to load funds onto the account with the online marketplace, especially for users who have not loaded funds before, or who do not already have an associated payment account. Themobile device 104 or the online marketplace can provide these instructions when the account balance is below a threshold, or when the user is within a threshold distance from a location that can load funds onto the account by scanning a barcode. Similarly, themobile device 104 can incorporate a location based alert to wake themobile phone 104 up when within the threshold distance, and automatically display the barcode, whether by opening an app or by temporarily changing a wallpaper of the mobile device lock screen, for example. - The
mobile device 104 can determine location data based on GPS signals and latitude and longitude coordinates. Themobile device 104 or theonline marketplace server 108 can then compare the coordinates to a database of known merchants and point of sale locations. Alternatively, a merchant can install a Wi-Fi transmitter or other wireless device that provides an identifier to themobile device 104 indicating a location of the mobile device. This approach can be helpful for mobile devices that are not always connected or do not have GPS hardware, such as portable music players or tablets. For example, a merchant can install a Bluetooth™ puck that broadcasts location data or a location identifier that themobile device 104 can use when generating a barcode to be scanned for a transaction with theonline marketplace server 108. - Having disclosed some basic system components and concepts, the disclosure now turns to the exemplary method embodiments shown in
FIGS. 5-7 . For the sake of clarity, each of the methods is described in terms of anexemplary system 800 as shown inFIG. 8 configured to practice the respective method. The steps outlined herein are exemplary and can be implemented in any combination thereof, including combinations that exclude, reorder, add, or modify certain steps. -
FIG. 5 illustrates an example method embodiment for enrolling a user. The system receives, from a user device and at an authentication server of an online marketplace, an enrollment request, wherein the enrollment request identifies a user account with the online marketplace, the user account existing prior to the enrollment request (502). An app for managing bar codes from multiple sources on the user device can generate and transmit the enrollment request. The system can further receive, from the user device and at the authentication server of an online marketplace, additional account details as part of the enrollment request, and confirm the additional account details as part of an authentication routine. - In response to the enrollment request, the system can associate a serial number with the user account (504). The system can determine that an existing serial number has been associated with the user account prior to the enrollment request, and transmit the existing serial number to the user device instead of generating an entirely new serial number. In one aspect, a single serial number is used for all devices associated with the user account, while in another aspect, each device associated with the user account is associated with a different serial number. One user account can be associated with multiple serial numbers either in series or at the same time.
- The system can transmit the serial number to the user device for identifying the user account at a point of sale terminal (506). The system can transmit the serial number in plain text, as an encrypted message, encoded in an image of a machine-readable code, or as instructions for generating a machine-readable code. The machine-readable code can be an image for rendering on a display, or the machine readable code can be a specially formed text or image string. The machine-readable code can also include non-visual codes, such as an audio signal or a wireless transmission such as communication via NFC devices.
-
FIG. 6 illustrates an example method embodiment for processing a transaction from the standpoint of a merchant. The system can scan a machine-readable code presented on a display of a mobile device (602). The machine-readable code can be a quick response (QR) code, a linear barcode, a two dimensional barcode, or a matrix barcode, for example. The mobile device can present other types of visual and/or non-visual machine-readable codes. - The system can identify, from the machine-readable code, a serial number associated with a user account of an online marketplace (604). The system can receive payment of an amount of money (606). For example, the system can prompt a store clerk to enter the amount of money. The user can provide verbal instructions regarding the amount of money or can enter the amount on a keypad on the point of sale equipment, or via the mobile device itself.
- The system can transmit to the online marketplace the serial number and an indication of the amount of money as part of a payment transaction for applying the amount of money to the user account (608). The system can further identify, from the machine-readable code, location data of the mobile device, and transmit the location data to the online marketplace. The system can receive a confirmation of the payment transaction (610). In one variation, the system receives, from the online marketplace, a balance of the user account, and determines a top-up amount based on the balance. Then the system can suggest the top-up amount as the amount of money to load onto the account. For example, the system can determine an amount that is greater than $20.00 that, if added to the balance, would total the next even multiple of $5.00. If the user has a balance of $13.29, the system can suggest a top-up amount of $21.71 to reach a total of $35.00. The exact rules for suggesting top-up amounts may vary, and can be user-configurable. If the user does not configure settings for making top-up amount recommendations, the system can apply system defaults. Further, the user can enable or disable such top-up recommendations altogether.
-
FIG. 7 illustrates an example method embodiment for processing a transaction from the standpoint of an online marketplace server. The system can receive, from a point of sale device and as part of a request to process a payment transaction, a serial number and an indication of an amount of money, wherein the serial number was obtained by scanning a machine-readable code presented on a display of a mobile device (702). In one embodiment, the online marketplace provided the machine-readable code to the mobile device. - The system can identify, based on the serial number, a user account of an online marketplace (704). The serial number can be associated with a user account of the mobile device, or with a second user account other than the user account with which the serial number is associated. When the serial number is associated with a second user account, the system can receive an indication of an amount of credit to transfer from the second user account to the user account, and transfer the amount of credit from the second user account to the user account. This can enable a user to transfer credit between accounts, such as a parent managing credit among children's accounts, or such as a friend giving a gift.
- When giving a gift of a transfer of credit from one user account to another user account, the barcode can encode additional information such as a message or electronic card from the giver to the recipient. The additional information can include instructions to the
online marketplace server 108 for how or when to deliver the transfer of credit. Alternatively, this additional information can be gathered via an app on themobile device 104 and transmitted separately to theonline marketplace server 108 with an identifier for matching up the additional information with a specific transaction. Then theonline marketplace server 108 can match the message with the transaction, and push a notification to a mobile device of the recipient, including at least part of the additional message. - The system can receive from the point of sale device a payment associated with the payment transaction (706) and apply the amount of money to the user account of the online marketplace (708). The system can transmit, to the point of sale device, a confirmation of the payment transaction (710). The system can also push a notification to the mobile device of the confirmation of the payment transaction. The notification can be a pop-up or email, for example. However, in one variation, the system pushes a notification to the mobile device that simply updates the
balance 406, such as in theexample user interface 400 ofFIG. 4 . In this way, the user can simply watch theuser interface 400 and confirm that the transaction was successful simply based on the updatedbalance 406. - In yet another embodiment describing the mobile device presenting the barcode at the point of sale, the system can receive, at a mobile device, a request to initiate a payment transaction for a user account with an online marketplace. The system can retrieve, from a memory of the mobile device, a serial number associated with the user account. Then system can generate a machine-readable code storing the serial number. The system can present, on a display of the mobile device, the machine-readable code to be scanned by a point of sale device as part of the payment transaction. The machine-readable code can encode additional data including at least one of location data, user account data, credentials, an amount associated with the payment transaction, a timestamp, or a personal identification number (PIN). The serial number can be associated with the user account during an enrollment process prior to the request to initiate the payment transaction.
- A brief description of a basic general purpose system or computing device in
FIG. 8 which can be employed to practice the concepts, methods, and techniques is disclosed below. With reference toFIG. 8 , an exemplary system and/orcomputing device 800 includes a processing unit (CPU or processor) 820 and asystem bus 810 that couples various system components including thesystem memory 830 such as read only memory (ROM) 840 and random access memory (RAM) 850 to theprocessor 820. Thesystem 800 can include acache 822 of high-speed memory connected directly with, in close proximity to, or integrated as part of theprocessor 820. Thesystem 800 copies data from thememory 830 and/or thestorage device 860 to thecache 822 for quick access by theprocessor 820. In this way, the cache provides a performance boost that avoidsprocessor 820 delays while waiting for data. These and other modules can control or be configured to control theprocessor 820 to perform various operations or actions.Other system memory 830 may be available for use as well. Thememory 830 can include multiple different types of memory with different performance characteristics. It can be appreciated that the disclosure may operate on acomputing device 800 with more than oneprocessor 820 or on a group or cluster of computing devices networked together to provide greater processing capability. Theprocessor 820 can include any general purpose processor and a hardware module or software module, such asmodule 1 862,module 2 864, andmodule 3 866 stored instorage device 860, configured to control theprocessor 820 as well as a special-purpose processor where software instructions are incorporated into the processor. Theprocessor 820 may be a self-contained computing system, containing multiple cores or processors, a bus, memory controller, cache, etc. A multi-core processor may be symmetric or asymmetric. Theprocessor 820 can include multiple processors, such as a system having multiple, physically separate processors in different sockets, or a system having multiple processor cores on a single physical chip. Similarly, theprocessor 820 can include multiple distributed processors located in multiple separate computing devices, but working together such as via a communications network. Multiple processors or processor cores can share resources such asmemory 830 or thecache 822, or can operate using independent resources. Theprocessor 820 can include one or more of a state machine, an application specific integrated circuit (ASIC), or a programmable gate array (PGA) including a field PGA. - The
system bus 810 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. A basic input/output (BIOS) stored inROM 840 or the like, may provide the basic routine that helps to transfer information between elements within thecomputing device 800, such as during start-up. Thecomputing device 800 further includesstorage devices 860 or computer-readable storage media such as a hard disk drive, a magnetic disk drive, an optical disk drive, tape drive, solid-state drive, RAM drive, removable storage devices, a redundant array of inexpensive disks (RAID), hybrid storage device, or the like. Thestorage device 860 can includesoftware modules processor 820. Thesystem 800 can include other hardware or software modules. Thestorage device 860 is connected to thesystem bus 810 by a drive interface. The drives and the associated computer-readable storage devices provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for thecomputing device 800. In one aspect, a hardware module that performs a particular function includes the software component stored in a tangible computer-readable storage device in connection with the necessary hardware components, such as theprocessor 820,bus 810,display 870, and so forth, to carry out a particular function. In another aspect, the system can use a processor and computer-readable storage device to store instructions which, when executed by the processor, cause the processor to perform operations, a method or other specific actions. The basic components and appropriate variations can be modified depending on the type of device, such as whether thedevice 800 is a small, handheld computing device, a desktop computer, or a computer server. When theprocessor 820 executes instructions to perform “operations”, theprocessor 820 can perform the operations directly and/or facilitate, direct, or cooperate with another device or component to perform the operations. - Although the exemplary embodiment(s) described herein employs the
hard disk 860, other types of computer-readable storage devices which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, digital versatile disks (DVDs), cartridges, random access memories (RAMs) 850, read only memory (ROM) 840, a cable containing a bit stream and the like, may also be used in the exemplary operating environment. Tangible computer-readable storage media, computer-readable storage devices, or computer-readable memory devices, expressly exclude media such as transitory waves, energy, carrier signals, electromagnetic waves, and signals per se. - To enable user interaction with the
computing device 800, aninput device 890 represents any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. Anoutput device 870 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems enable a user to provide multiple types of input to communicate with thecomputing device 800. Thecommunications interface 880 generally governs and manages the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic hardware depicted may easily be substituted for improved hardware or firmware arrangements as they are developed. - For clarity of explanation, the illustrative system embodiment is presented as including individual functional blocks including functional blocks labeled as a “processor” or
processor 820. The functions these blocks represent may be provided through the use of either shared or dedicated hardware, including, but not limited to, hardware capable of executing software and hardware, such as aprocessor 820, that is purpose-built to operate as an equivalent to software executing on a general purpose processor. For example the functions of one or more processors presented inFIG. 8 may be provided by a single shared processor or multiple processors. (Use of the term “processor” should not be construed to refer exclusively to hardware capable of executing software.) Illustrative embodiments may include microprocessor and/or digital signal processor (DSP) hardware, read-only memory (ROM) 840 for storing software performing the operations described below, and random access memory (RAM) 850 for storing results. Very large scale integration (VLSI) hardware embodiments, as well as custom VLSI circuitry in combination with a general purpose DSP circuit, may also be provided. - The logical operations of the various embodiments are implemented as: (1) a sequence of computer implemented steps, operations, or procedures running on a programmable circuit within a general use computer, (2) a sequence of computer implemented steps, operations, or procedures running on a specific-use programmable circuit; and/or (3) interconnected machine modules or program engines within the programmable circuits. The
system 800 shown inFIG. 8 can practice all or part of the recited methods, can be a part of the recited systems, and/or can operate according to instructions in the recited tangible computer-readable storage devices. Such logical operations can be implemented as modules configured to control theprocessor 820 to perform particular functions according to the programming of the module. For example,FIG. 8 illustrates threemodules Mod1 862,Mod2 864 andMod3 866 which are modules configured to control theprocessor 820. These modules may be stored on thestorage device 860 and loaded intoRAM 850 ormemory 830 at runtime or may be stored in other computer-readable memory locations. - One or more parts of the
example computing device 800, up to and including theentire computing device 800, can be virtualized. For example, a virtual processor can be a software object that executes according to a particular instruction set, even when a physical processor of the same type as the virtual processor is unavailable. A virtualization layer or a virtual “host” can enable virtualized components of one or more different computing devices or device types by translating virtualized operations to actual operations. Ultimately however, virtualized hardware of every type is implemented or executed by some underlying physical hardware. Thus, a virtualization compute layer can operate on top of a physical compute layer. The virtualization compute layer can include one or more of a virtual machine, an overlay network, a hypervisor, virtual switching, and any other virtualization application. - The
processor 820 can include all types of processors disclosed herein, including a virtual processor. However, when referring to a virtual processor, theprocessor 820 includes the software components associated with executing the virtual processor in a virtualization layer and underlying hardware necessary to execute the virtualization layer. Thesystem 800 can include a physical orvirtual processor 820 that receive instructions stored in a computer-readable storage device, which cause theprocessor 820 to perform certain operations. When referring to avirtual processor 820, the system also includes the underlying physical hardware executing thevirtual processor 820. - Embodiments within the scope of the present disclosure may also include tangible and/or non-transitory computer-readable storage devices for carrying or having computer-executable instructions or data structures stored thereon. Such tangible computer-readable storage devices can be any available device that can be accessed by a general purpose or special purpose computer, including the functional design of any special purpose processor as described above. By way of example, and not limitation, such tangible computer-readable devices can include RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other device which can be used to carry or store desired program code in the form of computer-executable instructions, data structures, or processor chip design. When information or instructions are provided via a network or another communications connection (either hardwired, wireless, or combination thereof) to a computer, the computer properly views the connection as a computer-readable medium. Thus, any such connection is properly termed a computer-readable medium. Combinations of the above should also be included within the scope of the computer-readable storage devices.
- Computer-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Computer-executable instructions also include program modules that are executed by computers in stand-alone or network environments. Generally, program modules include routines, programs, components, data structures, objects, and the functions inherent in the design of special-purpose processors, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of the program code means for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps.
- Other embodiments of the disclosure may be practiced in network computing environments with many types of computer system configurations, including personal computers, hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. Embodiments may also be practiced in distributed computing environments where tasks are performed by local and remote processing devices that are linked (either by hardwired links, wireless links, or by a combination thereof) through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
- The various embodiments described above are provided by way of illustration only and should not be construed to limit the scope of the disclosure. Various modifications and changes may be made to the principles described herein without following the example embodiments and applications illustrated and described herein, and without departing from the spirit and scope of the disclosure. Claim language reciting “at least one of” a set indicates that one member of the set or multiple members of the set satisfy the claim.
Claims (20)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/846,802 US20200242585A1 (en) | 2014-03-03 | 2020-04-13 | Processing payments for an online marketplace |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/195,773 US10621570B2 (en) | 2014-03-03 | 2014-03-03 | Processing payments for an online marketplace |
US16/846,802 US20200242585A1 (en) | 2014-03-03 | 2020-04-13 | Processing payments for an online marketplace |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/195,773 Continuation US10621570B2 (en) | 2014-03-03 | 2014-03-03 | Processing payments for an online marketplace |
Publications (1)
Publication Number | Publication Date |
---|---|
US20200242585A1 true US20200242585A1 (en) | 2020-07-30 |
Family
ID=52727397
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/195,773 Active 2035-06-03 US10621570B2 (en) | 2014-03-03 | 2014-03-03 | Processing payments for an online marketplace |
US16/846,802 Pending US20200242585A1 (en) | 2014-03-03 | 2020-04-13 | Processing payments for an online marketplace |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/195,773 Active 2035-06-03 US10621570B2 (en) | 2014-03-03 | 2014-03-03 | Processing payments for an online marketplace |
Country Status (2)
Country | Link |
---|---|
US (2) | US10621570B2 (en) |
WO (1) | WO2015134403A1 (en) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10977650B2 (en) * | 2013-10-30 | 2021-04-13 | Tencent Technology (Shenzhen) Company Limited | Information transmission method, apparatus and system |
US11069379B2 (en) * | 2012-03-12 | 2021-07-20 | BrandActif Ltd. | Intelligent print recognition system and method |
US11301906B2 (en) | 2020-03-03 | 2022-04-12 | BrandActif Ltd. | Method and system for digital marketing and the provision of digital content |
US20220191049A1 (en) * | 2020-12-10 | 2022-06-16 | The Alfred E. Mann Foundation For Scientific Research | Single-certificate multi-factor authentication |
US11593843B2 (en) | 2020-03-02 | 2023-02-28 | BrandActif Ltd. | Sponsor driven digital marketing for live television broadcast |
US20230213263A1 (en) * | 2022-01-05 | 2023-07-06 | Brumate, Inc. | Multi-function cooler |
US11854047B2 (en) | 2020-03-03 | 2023-12-26 | BrandActif Ltd. | Method and system for digital marketing and the provision of digital content |
Families Citing this family (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR101516773B1 (en) * | 2013-03-06 | 2015-05-04 | 홍바울 | Payment system using barcode and method thereof |
US11080739B2 (en) * | 2014-04-25 | 2021-08-03 | R.J. Reynolds Tobacco Company | Data translator |
US9454749B2 (en) | 2014-08-28 | 2016-09-27 | International Business Machines Corporation | Communication of configuration using an encoded visual representation |
US9300651B2 (en) * | 2014-08-28 | 2016-03-29 | International Business Machines Corporation | Verification of configuration using an encoded visual representation |
US10083488B2 (en) * | 2014-10-23 | 2018-09-25 | Salesforce.Com, Inc. | Purchasing contact information from an electronically displayed map |
US10178166B2 (en) * | 2014-12-08 | 2019-01-08 | Ebay Inc. | Delivering personalized content to authenticated user devices |
US11388226B1 (en) * | 2015-01-13 | 2022-07-12 | Snap Inc. | Guided personal identity based actions |
US11062345B2 (en) | 2015-05-13 | 2021-07-13 | Abl Ip Holding, Llc | Systems and methods for activity measurement around pop displays with wireless beacons |
US10339736B2 (en) * | 2016-01-27 | 2019-07-02 | Honeywell International Inc. | Remote application for controlling access |
US11227311B2 (en) | 2016-10-05 | 2022-01-18 | Abl Ip Holding, Llc | Local data acquisition for retail displays with wireless beacons |
CN107016420B (en) * | 2016-12-08 | 2022-01-28 | 创新先进技术有限公司 | Service processing method and device |
CN108257016B (en) * | 2016-12-29 | 2021-12-07 | 平安科技(深圳)有限公司 | Data processing method and device |
US20180374069A1 (en) | 2017-05-19 | 2018-12-27 | Shelfbucks, Inc. | Pressure-sensitive device for product tracking on product shelves |
EP3471038A1 (en) * | 2017-10-13 | 2019-04-17 | Mastercard International Incorporated | User authentication and transaction staging |
US11195242B1 (en) | 2019-02-27 | 2021-12-07 | United Services Automobile Association (Usaa) | Systems and methods for anonymizing transaction information |
US11697301B2 (en) * | 2020-11-10 | 2023-07-11 | Baysoft LLC | Remotely programmable wearable device |
US20230043398A1 (en) * | 2021-08-03 | 2023-02-09 | Ebay Inc. | Virtual Account Use |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100138344A1 (en) * | 2008-12-02 | 2010-06-03 | Ebay Inc. | Mobile barcode generation and payment |
US8126815B2 (en) * | 2001-12-19 | 2012-02-28 | Siemens It Solutions And Services Gmbh | Method and system for carrying out verification processes including optical scanning of information displayed via a mobile telephone terminal |
US8468054B1 (en) * | 2009-08-21 | 2013-06-18 | Cardstar, Inc. | Identification related technology |
US20130282588A1 (en) * | 2012-04-22 | 2013-10-24 | John Hruska | Consumer, Merchant and Mobile Device Specific, Real-Time Dynamic Tokenization Activation within a Secure Mobile-Wallet Financial Transaction System |
US8924292B1 (en) * | 2012-04-25 | 2014-12-30 | Wells Fargo Bank, N.A. | System and method for a mobile wallet |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5466920A (en) * | 1991-11-08 | 1995-11-14 | Microbilt Corporation | Real time decoding for card transaction terminal |
WO2007024151A1 (en) * | 2005-08-22 | 2007-03-01 | G-Xchange, Inc. | A method of converting cash into virtual cash and loading it to mobile phone cash account |
US8352323B2 (en) | 2007-11-30 | 2013-01-08 | Blaze Mobile, Inc. | Conducting an online payment transaction using an NFC enabled mobile communication device |
US8249965B2 (en) | 2006-03-30 | 2012-08-21 | Obopay, Inc. | Member-supported mobile payment system |
US8489067B2 (en) | 2006-07-06 | 2013-07-16 | Qualcomm Incorporated | Methods and systems for distribution of a mobile wallet for a mobile device |
US8793184B2 (en) | 2007-02-12 | 2014-07-29 | Visa U.S.A. Inc. | Mobile payment services |
WO2011032263A1 (en) | 2009-09-17 | 2011-03-24 | Meir Weis | Mobile payment system with two-point authentication |
WO2011097329A2 (en) * | 2010-02-03 | 2011-08-11 | Trilogy Ip Holdings, Inc. | Mobile communication plan offerings |
US20120078751A1 (en) * | 2010-09-24 | 2012-03-29 | Macphail William | Mobile device point of sale transaction system |
US9076171B2 (en) * | 2010-12-15 | 2015-07-07 | Symantec Corporation | Automatic electronic payments via mobile communication device with imaging system |
US20130346305A1 (en) | 2012-06-26 | 2013-12-26 | Carta Worldwide Inc. | Mobile wallet payment processing |
CA3096307C (en) * | 2012-06-27 | 2023-01-24 | Moneris Solutions Corporation | Secure payment system |
-
2014
- 2014-03-03 US US14/195,773 patent/US10621570B2/en active Active
-
2015
- 2015-03-02 WO PCT/US2015/018351 patent/WO2015134403A1/en active Application Filing
-
2020
- 2020-04-13 US US16/846,802 patent/US20200242585A1/en active Pending
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8126815B2 (en) * | 2001-12-19 | 2012-02-28 | Siemens It Solutions And Services Gmbh | Method and system for carrying out verification processes including optical scanning of information displayed via a mobile telephone terminal |
US20100138344A1 (en) * | 2008-12-02 | 2010-06-03 | Ebay Inc. | Mobile barcode generation and payment |
US8468054B1 (en) * | 2009-08-21 | 2013-06-18 | Cardstar, Inc. | Identification related technology |
US20130282588A1 (en) * | 2012-04-22 | 2013-10-24 | John Hruska | Consumer, Merchant and Mobile Device Specific, Real-Time Dynamic Tokenization Activation within a Secure Mobile-Wallet Financial Transaction System |
US8924292B1 (en) * | 2012-04-25 | 2014-12-30 | Wells Fargo Bank, N.A. | System and method for a mobile wallet |
Cited By (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11069379B2 (en) * | 2012-03-12 | 2021-07-20 | BrandActif Ltd. | Intelligent print recognition system and method |
US11972428B2 (en) | 2013-10-30 | 2024-04-30 | Tencent Technology (Shenzhen) Company Limited | Information transmission method, apparatus and system |
US10977650B2 (en) * | 2013-10-30 | 2021-04-13 | Tencent Technology (Shenzhen) Company Limited | Information transmission method, apparatus and system |
US11798038B2 (en) | 2020-03-02 | 2023-10-24 | BrandActif Ltd. | Method and system for digital marketing and the provision of digital content |
US11593843B2 (en) | 2020-03-02 | 2023-02-28 | BrandActif Ltd. | Sponsor driven digital marketing for live television broadcast |
US11854047B2 (en) | 2020-03-03 | 2023-12-26 | BrandActif Ltd. | Method and system for digital marketing and the provision of digital content |
US11922464B2 (en) | 2020-03-03 | 2024-03-05 | BrandActif Ltd. | Sponsor driven digital marketing for live television broadcast |
US11301906B2 (en) | 2020-03-03 | 2022-04-12 | BrandActif Ltd. | Method and system for digital marketing and the provision of digital content |
US12086836B2 (en) | 2020-03-03 | 2024-09-10 | BrandActif Ltd. | Method and system for digital marketing and the provision of digital content |
US11856113B2 (en) * | 2020-12-10 | 2023-12-26 | The Alfred E. Mann Foundation For Scientific Research | Single-certificate multi-factor authentication |
US20220191049A1 (en) * | 2020-12-10 | 2022-06-16 | The Alfred E. Mann Foundation For Scientific Research | Single-certificate multi-factor authentication |
US20230213263A1 (en) * | 2022-01-05 | 2023-07-06 | Brumate, Inc. | Multi-function cooler |
US11852406B2 (en) | 2022-01-05 | 2023-12-26 | Brumate, Inc. | Multi-function cooler |
US12117238B2 (en) * | 2022-01-05 | 2024-10-15 | Brumate, Inc. | Multi-function cooler |
Also Published As
Publication number | Publication date |
---|---|
US10621570B2 (en) | 2020-04-14 |
WO2015134403A1 (en) | 2015-09-11 |
US20150248663A1 (en) | 2015-09-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20200242585A1 (en) | Processing payments for an online marketplace | |
US10846708B2 (en) | Systems and methods for enrolling a user in a membership account | |
US10192210B2 (en) | Automatically emailing receipt at POS | |
US10628821B2 (en) | Activation and assigning value to gift cards using RFID | |
US20140074605A1 (en) | Systems and methods for facilitating purchases at a gas station via mobile commerce | |
US11132654B2 (en) | Systems and methods for third party payment at point of sale terminals | |
CN108431847A (en) | Determine digital wallet Client-initiated be currently based on wallet transaction whether be fraudulent method | |
US12093926B2 (en) | Profile association and transaction authorization based on transaction type | |
US10878402B1 (en) | Temporarily provisioning payment functionality to alternate payment instrument | |
US11983701B2 (en) | Temporarily provisioning card on file payment functionality to proximate merchants | |
WO2013120007A1 (en) | Using credit card/bank rails to access a user's account at a pos | |
WO2018164638A1 (en) | Customer-initiated payment system and process | |
CN104657854B (en) | Allow the wireless power source of payment transaction | |
US20140183257A1 (en) | Providing user information by presenting readable indicia with mobile device | |
US20170255930A1 (en) | Method for providing electronic payment function and electronic device supporting the same | |
US20190156389A1 (en) | Shopping management systems and associated methods | |
KR102431265B1 (en) | A method and apparatus for providing a service linked with payment based on a locatoin of mobile device | |
US11222334B2 (en) | Processing electronic payments on a mobile computer device | |
US20140258107A1 (en) | Generating personal bank note using readable indicia | |
US20140236823A1 (en) | Online Prepaid Gift Card Identification | |
US20140183255A1 (en) | Providing information from use of readable indicia with mobile device | |
US11386418B1 (en) | Dynamic actions from matrix codes | |
CA2980946C (en) | Activation and assigning value to gift cards using rfid | |
US10635995B2 (en) | Systems and methods for facilitating event access through payment accounts | |
US20180374066A1 (en) | Systems and Methods for Use in Facilitating Transactions to Payment Accounts |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |