US20140379558A1 - Extensible Interface for Synchronous and Asynchronous Payment - Google Patents
Extensible Interface for Synchronous and Asynchronous Payment Download PDFInfo
- Publication number
- US20140379558A1 US20140379558A1 US13/923,284 US201313923284A US2014379558A1 US 20140379558 A1 US20140379558 A1 US 20140379558A1 US 201313923284 A US201313923284 A US 201313923284A US 2014379558 A1 US2014379558 A1 US 2014379558A1
- Authority
- US
- United States
- Prior art keywords
- payment
- interface
- commerce
- user
- asynchronous
- 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.)
- Abandoned
Links
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/02—Payment architectures, schemes or protocols involving a neutral party, e.g. certification authority, notary or trusted third party [TTP]
- G06Q20/027—Payment architectures, schemes or protocols involving a neutral party, e.g. certification authority, notary or trusted third party [TTP] involving a payment switch or gateway
-
- 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/34—Payment architectures, schemes or protocols characterised by the use of specific devices or networks using cards, e.g. integrated circuit [IC] cards or magnetic cards
- G06Q20/356—Aspects of software for card payments
-
- 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
- G06Q30/00—Commerce
- G06Q30/06—Buying, selling or leasing transactions
- G06Q30/0601—Electronic shopping [e-shopping]
-
- G—PHYSICS
- G07—CHECKING-DEVICES
- G07F—COIN-FREED OR LIKE APPARATUS
- G07F19/00—Complete banking systems; Coded card-freed arrangements adapted for dispensing or receiving monies or the like and posting such transactions to existing accounts, e.g. automatic teller machines
- G07F19/20—Automatic teller machines [ATMs]
- G07F19/211—Software architecture within ATMs or in relation to the ATM network
Definitions
- the payment systems include those that use credit cards and others that perform secure payment moving money from one party (e.g., a purchaser) to another party (e.g., a vendor).
- a party e.g., a purchaser
- a vendor e.g., a vendor
- differences between such systems result in difficulty for developers, and the need to change code within their e-commerce applications.
- One difficulty faced by developers is the need to code for both synchronous and asynchronous payment systems. Accordingly, application development and maintenance is made more difficult as the number of payment systems grows. Moreover, applications that fail to overcome such difficulties in a timely manner fail to satisfy users' expectations.
- FIG. 1 is a diagram showing an example of a system for performing e-commerce payments, including example detail of a client operating an e-commerce application.
- FIG. 2 is a diagram showing an example of a system for performing e-commerce payments, including example detail of a commerce platform and detail of client operation in performing an asynchronous payment.
- FIG. 3 is a timing and event diagram showing example of aspects of both synchronous and asynchronous transactions.
- FIG. 4 is a flow diagram showing an example method to perform an e-commerce payment.
- FIG. 5 is a flow diagram showing an example method to perform an asynchronous payment after failure of a synchronous payment.
- FIG. 6 is a flow diagram showing an example method to extend a number of payment systems available to e-commerce applications.
- FIG. 7 is a flow diagram showing an example method to perform cleanup in the event of an e-commerce payment failure.
- the disclosure describes techniques by which an e-commerce application may make payments in a plurality of markets, using a plurality of payment systems, and/or according to a plurality of different payment methods.
- the techniques are performed by an interface, such as an application programming interface (API) utilized by an operating system on which an e-commerce application may be operating.
- API application programming interface
- the API may be made available to developers of such e-commerce applications.
- the API may significantly reduce the burden on the developers of e-commerce applications, such as burdens associated with adapting to additional payment systems.
- periodic enhancements to the API to accommodate additional payment systems and methods may be performed, thereby avoiding the need for changes to the e-commerce applications.
- the techniques provide for transactions that may be either synchronous or asynchronous.
- a synchronous payment method such as most credit card payments (e.g., those without a secondary authentication (e.g., Verified by Visa®))
- the payment and title to the goods and/or services are synchronously exchanged, such as by completion of a credit card charge. Examples of credit cards include VISA®, American Express® and others.
- asynchronous payment method such as a bank transfer, intermediate steps are required to perform the transfer. Such intermediate steps may include having the user log into a website of the asynchronous payment system and provide password(s) and/or other information. Allpay® and other payment systems that require secondary user step(s) are examples of asynchronous payment systems.
- the e-commerce application running on a computing device may call the API.
- the API may be part of, or associated with, the operating system of the client device.
- the API may redirect the user to a webpage associated with the asynchronous payment system while leaving a modal dialog (e.g., dialog box or related graphical user interface element or object) on the application.
- a modal dialog e.g., dialog box or related graphical user interface element or object
- the “store” with which the e-commerce application is communicating has a record of the pending purchase.
- a commerce platform may also receive a record of the pending purchase.
- the commerce platform may comprise a plurality of servers that support transactions performed by the operating system of the computing device of the user and a plurality of e-commerce payment systems.
- the commerce platform handles aspects of the transaction between the e-commerce application and a vendor while the e-commerce application on the client device waits.
- the user may complete entry of payment information into the webpage associated with the asynchronous payment system. Upon receipt of this information by the asynchronous payment system, the webpage is removed and the user returns to the e-commerce application. The user then selects “continue” or similar on the modal dialog box. This signals a purchase process operating on the e-commerce store to poll the commerce platform for a status of the asynchronous purchase record. The polling continues as the commerce platform works with the asynchronous payment system to resolve the payment.
- the e-commerce application attempts to keep the user from leaving the purchase process until there is a success or failure of the purchase process.
- the API Upon receipt of a success or failure state, the API transmits the state to the e-commerce application.
- a pending state which may represent the processing of a payment in an asynchronous payment method, is not returned by the API. Accordingly, the API may provide a consistent result to the e-commerce application for both synchronous and asynchronous transactions.
- a cleanup job is run to determine a final status of the transaction. If the user tries to purchase the item again, prior to the cleanup job, the commerce platform is polled to determine a current status of the purchase, which is returned to the e-commerce application.
- FIG. 1 is a diagram showing an example of a system 100 for performing e-commerce payments.
- a client device 102 may be a laptop, tablet, smart phone, or any mobile and/or desktop computing device.
- the client device 102 may assist a user operating the client device to purchase goods and/or services from one or more vendors 104 .
- the purchase transaction may be performed using a payment system 106 , and may be assisted by a commerce platform 108 .
- the client device 102 may be in communication with one or more of the vendor(s) 104 , payment system(s) 106 and/or commerce platform 108 .
- the vendor(s) 104 may be any “store” or vendor configured to sell products and/or services, such as by using a website or other e-commerce techniques. Examples of such vendors include those selling books, electronics, tickets, game-level products and/or services, in-app purchases, on-line content, travel accommodations, etc.
- the payment system(s) 106 may be any third party (i.e., not the purchaser and not the vendor) system that is configured for performing and/or assisting in e-commerce payments.
- the client 102 may include a processing unit 110 , which may include one or more processors 112 and memory 114 .
- An operating system 116 may provide functionality to one or more applications, such as an e-commerce application 118 .
- the e-commerce application 118 may be configured to assist the user of the client device 102 to purchase goods or services from the vendor(s) 104 .
- the e-commerce application 118 may make calls to the operating system 116 , including an application programming interface (API) 120 .
- API application programming interface
- the API 120 is configured for use with either synchronous or asynchronous payment systems.
- the API 120 is configured for expansion or extension to work with a new and/or additional payment system (of synchronous or asynchronous type) without a change to an interface called by the e-commerce application 118 that would cause recoding and/or redesign of that application.
- FIG. 2 is a diagram showing another view and further example techniques of the system 100 for performing e-commerce payments.
- the view of FIG. 2 shows example detail of the commerce platform 108 and detail of operation of the client device 102 in the performance an asynchronous payment.
- the commerce platform 108 of FIG. 2 is representative of third party services with which the example application programming interface (API) 120 (shown in FIG. 1 ) of the client device 102 may communicate in the course of an e-commerce transaction.
- the commerce platform 108 is configured to assist certain devices (e.g., those having the Windows® operating system) to make e-commerce transactions.
- FIG. 2 shows example structures of the commerce platform 108 , which may be altered to fit the needs of any particular system within which the commerce platform is configured to operate.
- the commerce platform 108 includes a commerce web service 200 , a payment collection service 202 , commerce settings 204 , a commercial transaction license 206 and/or a cleanup pipeline 208 .
- the commerce web service 200 may be configured to receive an initial call from the API 120 of the client 102 and to communicate with one or more of a plurality of payment systems 106 .
- the payment collection service 202 may be configured to provide a user interface to the client, and in some instances to “wrap” a user interface of a payment system 106 to allow a user to enter payment information while still remaining within the environment of the commerce platform 108 .
- the commerce settings 204 may include a repository of settings, which may allow the commerce platform to operate seamlessly with a plurality of different third party payment systems 106 .
- the commerce transaction license 206 may be configured as a data file, database, or other data structure, and may be configured to record and/or indicate award of a license of ownership to the user after a successful e-commerce transaction.
- the cleanup pipeline and/or procedure 208 may be configured to handle incomplete transactions, such as if the user leaves the e-commerce application 118 prior to conclusion of the e-commerce transaction or if the user turns off the client device prior to
- FIG. 2 shows on example of how a user interface, directed at least in part by the API 120 and/or the commerce platform 108 , may “wrap” or otherwise manage a user interface configured at least in part by a payment system.
- the payment collection service (PCS) 202 has created a webpage 210 in response to the call from the API 120 .
- the payment collection webpage 210 has wrapped a webpage 212 presented by the payment system 106 .
- generic user interface elements may be used to provide the user with an experience including redirection to a webpage of a payment system without integration and/or contact between the application and the payment system. The redirection may be to a bank for transaction/purchase approval and/or to a website for approval.
- the generic user interface elements may be provided by the API, which may be extensible for interaction with other banks, websites and/or payment systems. Accordingly, the API 120 and/or the commerce platform 108 may exert some control over the experience of the user of the client 102 . In operation, the user may enter information requested by the webpage 212 for transmission to the third party payment system 106 .
- FIG. 3 is a timing and event diagram showing an example transaction 300 .
- the activities shown in the example transaction 300 may be performed on the client device 102 and on the commerce platform 108 . Activities shown as performed on the client device 102 may be performed on the e-commerce application 118 . Moreover, the activities shown as performed on the commerce platform 108 for example only, and the activities could be performed in other locations within a system 100 (such as that shown in the example of FIG. 1 ).
- the example transaction 300 shows techniques utilized by both synchronous and asynchronous payment systems, and shows how failure or error in performing a synchronous transaction may result in an attempt to perform an asynchronous transaction.
- the activities performed on the commerce platform 108 may be performed by use of the commerce web service 200 , a pending record 302 , the payment collection service (PCS) 202 and/or a commerce transaction license 206 .
- the pending record 302 may be a data structure maintained on the commerce platform 108 , for example.
- an e-commerce application e.g., e-commerce application 118 of FIG. 1
- the “calculate final price event” 304 is a specific example of a transaction that may be initiated by a call to the commerce web service 200 by the e-commerce application 118 on the client device 102 .
- goods and/or services may have been loaded into a “shopping cart” or other device or technique for purchase.
- the e-commerce application 118 may call to the operating system (e.g., operating system 116 of FIG. 1 ) such as by making a call to a “calculate final price” procedure or similar.
- a “no account exception” may be returned, which may provide the client device a uniform resource locator (URL, i.e., webpage address). Use of the URL may be used to establish a payment method and/or payment collection service.
- URL uniform resource locator
- the URL is utilized to contact a payment service, such as by operation of the payment collection service 202 .
- a payment service may be associated with a credit card, money transfer system or other payment service.
- the service returns information to the e-commerce application 118 running on the client device 102 , such as an account ID, a personal identification number, password, and/or other identifier.
- an account may be added for the user if an account was not identified by the “select payment method event” 306 .
- this action may be performed at least in part by the payment collection service 202 .
- a “get account event” 310 sets up and returns an account. This action may be recorded in the commerce transaction license 206 .
- a “get instruments event” 312 obtains documents and/or data, etc., that is required to make the purchase.
- a final price of the purchase is calculated by a call to the commerce web service 200 .
- a “purchase event” 316 may return a value of success or failure to the commerce web service 200 .
- a pending record is created. Such a record assists in scheduling the transaction and preventing its loss.
- a status of the purchase transaction is returned. If the purchase is a synchronous credit card transaction, the status may be “completed.” However, if the transaction is an asynchronous money transfer, a pending status may be returned.
- record update event a pending record is set to resume the purchase transaction. In the event of an error, it may be necessary to perform an asynchronous transaction.
- a payment collection service page 212 (an example of which is shown in FIG. 2 ) may be provided by the payment collection service 202 to wrap a webpage of a third party payment service, which may comprise an asynchronous money transfer service.
- the purchase is resumed, in the event of a failure at confirm purchase event 318 .
- the pending purchase record is found.
- the purchase record may have been created at “create record event” 320 , as noted above.
- the commerce platform 108 may respond to polls from the vendor or store, wherein the polling requests information about a status of the purchase.
- mark record as success event the record 302 is marked to indicate success or failure of the asynchronous payment process.
- FIG. 4 is a flow diagram showing an example payment method 400 to perform an e-commerce payment.
- an interface may be exposed to allow it to be called by applications.
- the applications programming interface (API) 120 is exposed to allow calls by the operating system 116 .
- a call is received at the interface regarding a purchase transaction from an e-commerce application.
- the e-commerce application 118 calls the API 120 in the course of performing an e-commerce transaction.
- the purchase transaction is examined to determine if an associated payment method is synchronous or asynchronous.
- the payment system and/or provider may provide an indication of whether the transaction is synchronous or asynchronous, thereby allowing the transaction to be handled appropriately.
- an examination of the transaction may be performed by the API 120 or by the commerce platform 108 to reveal if the purchase transaction is synchronous or asynchronous.
- the “confirm purchase event” 318 may return an error, indicating that a synchronous payment method has failed, and that the payment method may be asynchronous.
- a payment system is contacted. Communication with the payment system may result in performance of the purchase transaction.
- the purchase transaction may be based at least in part on the determination, at operation 406 , distinguishing between synchronous and asynchronous payment methods.
- a result of the purchase transaction is provided to the e-commerce application.
- FIG. 5 is a flow diagram showing an example error handling method 500 to perform an asynchronous payment after failure of a synchronous payment.
- a message e.g., an error message
- the error may be due to an inability of a system to process a purchase transaction as a synchronous purchase transaction.
- an error may be returned by the “confirm purchase event” 318 , indicating an error due to an asynchronous payment system.
- the payment system may be determined to be asynchronous.
- Asynchronous payment systems may be based on multi-step money transfer systems.
- such payment systems may include those having similarity to Verified by Visa, etc.
- credit cards which are normally synchronous, may be flagged to need extra authentication, thereby becoming asynchronous.
- a user interface may be provided to allow the user to communicate with a payment site associated with the asynchronous payment method.
- the payment collection webpage 210 of the payment collection service (PCS) 202 has wrapped a webpage 212 presented by the payment system 106 .
- a webpage associated with an asynchronous payment system is wrapped within a user interface, which may be provided by API 120 .
- the payment collection service webpage 212 from a vendor 104 is wrapped by the payment collection webpage 210 , which may be provided by the commerce platform or the API 120 .
- operation of the user interface may collect data for use by the asynchronous payment system.
- the data may include user names and/or passwords to allow a money transfer from one or more accounts associated with the asynchronous payment system (e.g., one or more bank accounts used by the asynchronous system).
- a user-facing dialog box may be provided by the API 120 until the transaction is completed.
- the dialog box may assist by approximating the experience the user would have during a synchronous payment process during the current asynchronous process.
- the dialog box may be any persistent user interface element that prevents user interaction with other portions of the application until the user has taken action on the dialog box itself In such an example, the dialog box or other user interface element persists until the user hits a “continue” or similar button. At that point, if the transaction is still pending, the dialog box may be changed to encourage the user to “try again” or “close” the dialog box, thereby ending the transaction with failure.
- a result of success of failure may be returned to the e-commerce application.
- the “mark record as success event” 334 may provide such a result to the e-commerce application.
- FIG. 6 is a flow diagram showing an example extensibility method 600 to extend a number of payment systems available to e-commerce applications.
- a number of payment systems for which the interface (e.g., API 120 of FIG. 1 ) is configured to handle purchase transactions is extended and/or increased.
- the API 120 may be extended to operate with each of them.
- the extension of the API may include additional executable statements to handle operation with each of the new payment systems.
- a format, protocol, etc., of calls to the interface may be maintained in an unchanged manner after the extension.
- the same calls by the e-commerce application 118 to the API 120 may be used in an unchanged manner after the extension, while new calls may additionally be available.
- FIG. 7 is a flow diagram showing an example cleanup method 700 to perform cleanup in the event of an e-commerce payment failure.
- an exit by a user of an e-commerce application may be detected.
- the user may exit the e-commerce application or may turn off the client device. This may leave any transaction in a state of uncertainty.
- a cleanup of the purchase transaction is performed.
- the cleanup may determine if a license has been granted to the user, and may return a status of the purchase transaction to the e-commerce application.
- Computer-readable media includes computer storage media and communication media.
- Computer storage media includes volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer-readable instructions, data structures, program modules, or other data.
- Computer storage media includes, but is not limited to, random access memory (RAM), read only memory (ROM), electrically erasable programmable ROM (EEPROM), flash memory or other memory technology, compact disk ROM (CD-ROM), digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store information for access by a computing device.
- communication media may embody computer-readable instructions, data structures, program modules, or other data that is defined in a modulated data signal, such as in conjunction with a carrier wave. As defined herein, computer storage media does not include communication media.
Landscapes
- Business, Economics & Management (AREA)
- Engineering & Computer Science (AREA)
- Accounting & Taxation (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Finance (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Microelectronics & Electronic Packaging (AREA)
- Software Systems (AREA)
- Development Economics (AREA)
- Economics (AREA)
- Marketing (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Information Transfer Between Computers (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Abstract
Description
- Many payment systems are available for use by customers of online retailers. The payment systems include those that use credit cards and others that perform secure payment moving money from one party (e.g., a purchaser) to another party (e.g., a vendor). However, as more payment systems become available, differences between such systems result in difficulty for developers, and the need to change code within their e-commerce applications. One difficulty faced by developers is the need to code for both synchronous and asynchronous payment systems. Accordingly, application development and maintenance is made more difficult as the number of payment systems grows. Moreover, applications that fail to overcome such difficulties in a timely manner fail to satisfy users' expectations.
- The detailed description is described with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The same numbers are used throughout the drawings to reference like features and components. Moreover, the figures are intended to illustrate general concepts, and not to indicate required and/or necessary elements.
-
FIG. 1 is a diagram showing an example of a system for performing e-commerce payments, including example detail of a client operating an e-commerce application. -
FIG. 2 is a diagram showing an example of a system for performing e-commerce payments, including example detail of a commerce platform and detail of client operation in performing an asynchronous payment. -
FIG. 3 is a timing and event diagram showing example of aspects of both synchronous and asynchronous transactions. -
FIG. 4 is a flow diagram showing an example method to perform an e-commerce payment. -
FIG. 5 is a flow diagram showing an example method to perform an asynchronous payment after failure of a synchronous payment. -
FIG. 6 is a flow diagram showing an example method to extend a number of payment systems available to e-commerce applications. -
FIG. 7 is a flow diagram showing an example method to perform cleanup in the event of an e-commerce payment failure. - The disclosure describes techniques by which an e-commerce application may make payments in a plurality of markets, using a plurality of payment systems, and/or according to a plurality of different payment methods. In one example, the techniques are performed by an interface, such as an application programming interface (API) utilized by an operating system on which an e-commerce application may be operating. The API may be made available to developers of such e-commerce applications.
- The API may significantly reduce the burden on the developers of e-commerce applications, such as burdens associated with adapting to additional payment systems. In one example, periodic enhancements to the API to accommodate additional payment systems and methods may be performed, thereby avoiding the need for changes to the e-commerce applications.
- The techniques provide for transactions that may be either synchronous or asynchronous. In a synchronous payment method, such as most credit card payments (e.g., those without a secondary authentication (e.g., Verified by Visa®)), the payment and title to the goods and/or services are synchronously exchanged, such as by completion of a credit card charge. Examples of credit cards include VISA®, American Express® and others. In an asynchronous payment method, such as a bank transfer, intermediate steps are required to perform the transfer. Such intermediate steps may include having the user log into a website of the asynchronous payment system and provide password(s) and/or other information. Allpay® and other payment systems that require secondary user step(s) are examples of asynchronous payment systems.
- While certain aspects of synchronous credit card transactions are known, an interface that may be utilized to seamlessly perform both synchronous and asynchronous transactions and which may be expanded to utilize new e-commerce payment systems without requiring changes to e-commerce applications, has not previously been known.
- In one example, when a user makes an in-application purchase using an asynchronous payment method, the e-commerce application running on a computing device may call the API. The API may be part of, or associated with, the operating system of the client device. The API may redirect the user to a webpage associated with the asynchronous payment system while leaving a modal dialog (e.g., dialog box or related graphical user interface element or object) on the application. Thus, a result is not immediately returned to the e-commerce application. This performance appears to the e-commerce application to be similar to a synchronous credit card transaction, wherein the application receives a result only when the purchase dialog closes. As the user is redirected to the webpage, the “store” with which the e-commerce application is communicating has a record of the pending purchase. Additionally, a commerce platform may also receive a record of the pending purchase. The commerce platform may comprise a plurality of servers that support transactions performed by the operating system of the computing device of the user and a plurality of e-commerce payment systems. In one example, the commerce platform handles aspects of the transaction between the e-commerce application and a vendor while the e-commerce application on the client device waits.
- The user may complete entry of payment information into the webpage associated with the asynchronous payment system. Upon receipt of this information by the asynchronous payment system, the webpage is removed and the user returns to the e-commerce application. The user then selects “continue” or similar on the modal dialog box. This signals a purchase process operating on the e-commerce store to poll the commerce platform for a status of the asynchronous purchase record. The polling continues as the commerce platform works with the asynchronous payment system to resolve the payment.
- The e-commerce application attempts to keep the user from leaving the purchase process until there is a success or failure of the purchase process. Upon receipt of a success or failure state, the API transmits the state to the e-commerce application. A pending state, which may represent the processing of a payment in an asynchronous payment method, is not returned by the API. Accordingly, the API may provide a consistent result to the e-commerce application for both synchronous and asynchronous transactions.
- If the user leaves the transaction (e.g., turns off the user's computing device or closes the e-commerce application) a cleanup job is run to determine a final status of the transaction. If the user tries to purchase the item again, prior to the cleanup job, the commerce platform is polled to determine a current status of the purchase, which is returned to the e-commerce application.
-
FIG. 1 is a diagram showing an example of asystem 100 for performing e-commerce payments. Aclient device 102 may be a laptop, tablet, smart phone, or any mobile and/or desktop computing device. Theclient device 102 may assist a user operating the client device to purchase goods and/or services from one ormore vendors 104. The purchase transaction may be performed using apayment system 106, and may be assisted by acommerce platform 108. - In the example of
FIG. 1 , theclient device 102 may be in communication with one or more of the vendor(s) 104, payment system(s) 106 and/orcommerce platform 108. The vendor(s) 104 may be any “store” or vendor configured to sell products and/or services, such as by using a website or other e-commerce techniques. Examples of such vendors include those selling books, electronics, tickets, game-level products and/or services, in-app purchases, on-line content, travel accommodations, etc. The payment system(s) 106 may be any third party (i.e., not the purchaser and not the vendor) system that is configured for performing and/or assisting in e-commerce payments. Such payments may be synchronous (i.e., using credit cards) or asynchronous (e.g., using bank transfer techniques). Theclient 102 may include aprocessing unit 110, which may include one ormore processors 112 andmemory 114. Anoperating system 116 may provide functionality to one or more applications, such as ane-commerce application 118. Thee-commerce application 118 may be configured to assist the user of theclient device 102 to purchase goods or services from the vendor(s) 104. To assist in purchase transactions, thee-commerce application 118 may make calls to theoperating system 116, including an application programming interface (API) 120. In one example, theAPI 120 is configured for use with either synchronous or asynchronous payment systems. In a further example, theAPI 120 is configured for expansion or extension to work with a new and/or additional payment system (of synchronous or asynchronous type) without a change to an interface called by thee-commerce application 118 that would cause recoding and/or redesign of that application. -
FIG. 2 is a diagram showing another view and further example techniques of thesystem 100 for performing e-commerce payments. The view ofFIG. 2 shows example detail of thecommerce platform 108 and detail of operation of theclient device 102 in the performance an asynchronous payment. - The
commerce platform 108 ofFIG. 2 is representative of third party services with which the example application programming interface (API) 120 (shown inFIG. 1 ) of theclient device 102 may communicate in the course of an e-commerce transaction. In one example, thecommerce platform 108 is configured to assist certain devices (e.g., those having the Windows® operating system) to make e-commerce transactions.FIG. 2 shows example structures of thecommerce platform 108, which may be altered to fit the needs of any particular system within which the commerce platform is configured to operate. In the example shown, thecommerce platform 108 includes acommerce web service 200, apayment collection service 202,commerce settings 204, acommercial transaction license 206 and/or acleanup pipeline 208. - The
commerce web service 200 may be configured to receive an initial call from theAPI 120 of theclient 102 and to communicate with one or more of a plurality ofpayment systems 106. Thepayment collection service 202 may be configured to provide a user interface to the client, and in some instances to “wrap” a user interface of apayment system 106 to allow a user to enter payment information while still remaining within the environment of thecommerce platform 108. Thecommerce settings 204 may include a repository of settings, which may allow the commerce platform to operate seamlessly with a plurality of different thirdparty payment systems 106. Thecommerce transaction license 206 may be configured as a data file, database, or other data structure, and may be configured to record and/or indicate award of a license of ownership to the user after a successful e-commerce transaction. The cleanup pipeline and/orprocedure 208 may be configured to handle incomplete transactions, such as if the user leaves thee-commerce application 118 prior to conclusion of the e-commerce transaction or if the user turns off the client device prior to the conclusion. -
FIG. 2 shows on example of how a user interface, directed at least in part by theAPI 120 and/or thecommerce platform 108, may “wrap” or otherwise manage a user interface configured at least in part by a payment system. In the example shown, the payment collection service (PCS) 202 has created awebpage 210 in response to the call from theAPI 120. Thepayment collection webpage 210 has wrapped awebpage 212 presented by thepayment system 106. In a more general example, generic user interface elements may be used to provide the user with an experience including redirection to a webpage of a payment system without integration and/or contact between the application and the payment system. The redirection may be to a bank for transaction/purchase approval and/or to a website for approval. The generic user interface elements may be provided by the API, which may be extensible for interaction with other banks, websites and/or payment systems. Accordingly, theAPI 120 and/or thecommerce platform 108 may exert some control over the experience of the user of theclient 102. In operation, the user may enter information requested by thewebpage 212 for transmission to the thirdparty payment system 106. -
FIG. 3 is a timing and event diagram showing anexample transaction 300. The activities shown in theexample transaction 300 may be performed on theclient device 102 and on thecommerce platform 108. Activities shown as performed on theclient device 102 may be performed on thee-commerce application 118. Moreover, the activities shown as performed on thecommerce platform 108 for example only, and the activities could be performed in other locations within a system 100 (such as that shown in the example ofFIG. 1 ). Theexample transaction 300 shows techniques utilized by both synchronous and asynchronous payment systems, and shows how failure or error in performing a synchronous transaction may result in an attempt to perform an asynchronous transaction. - In the example of
FIG. 3 , the activities performed on thecommerce platform 108 may be performed by use of thecommerce web service 200, a pendingrecord 302, the payment collection service (PCS) 202 and/or acommerce transaction license 206. The pendingrecord 302 may be a data structure maintained on thecommerce platform 108, for example. At theclient device 102, an e-commerce application (e.g.,e-commerce application 118 ofFIG. 1 ) may operate to assist a user in making an e-commerce purchase on a website. - The “calculate final price event” 304 is a specific example of a transaction that may be initiated by a call to the
commerce web service 200 by thee-commerce application 118 on theclient device 102. At this point, goods and/or services may have been loaded into a “shopping cart” or other device or technique for purchase. Thee-commerce application 118 may call to the operating system (e.g.,operating system 116 ofFIG. 1 ) such as by making a call to a “calculate final price” procedure or similar. In the example shown, a “no account exception” may be returned, which may provide the client device a uniform resource locator (URL, i.e., webpage address). Use of the URL may be used to establish a payment method and/or payment collection service. - At “select payment method event” 306, the URL is utilized to contact a payment service, such as by operation of the
payment collection service 202. Such a payment service may be associated with a credit card, money transfer system or other payment service. The service returns information to thee-commerce application 118 running on theclient device 102, such as an account ID, a personal identification number, password, and/or other identifier. - At “add payment account event” 308, an account may be added for the user if an account was not identified by the “select payment method event” 306. In the example of
FIG. 3 , this action may be performed at least in part by thepayment collection service 202. In one example, a “get account event” 310 sets up and returns an account. This action may be recorded in thecommerce transaction license 206. A “get instruments event” 312 obtains documents and/or data, etc., that is required to make the purchase. - At “calculate final price event” 314, a final price of the purchase is calculated by a call to the
commerce web service 200. In one example, a “purchase event” 316 may return a value of success or failure to thecommerce web service 200. - At a “confirm purchase event” 318, the purchase may be confirmed. At “create record event” 320, a pending record is created. Such a record assists in scheduling the transaction and preventing its loss. At a “purchase event” 322 a status of the purchase transaction is returned. If the purchase is a synchronous credit card transaction, the status may be “completed.” However, if the transaction is an asynchronous money transfer, a pending status may be returned. At “record update event” 324, a pending record is set to resume the purchase transaction. In the event of an error, it may be necessary to perform an asynchronous transaction.
- At “load PCS page event” 326, payment collection webpage is loaded. In one example, a payment collection service page 212 (an example of which is shown in
FIG. 2 ) may be provided by thepayment collection service 202 to wrap a webpage of a third party payment service, which may comprise an asynchronous money transfer service. - At “resume purchase event” 328, the purchase is resumed, in the event of a failure at
confirm purchase event 318. At “find pending record event” 330, the pending purchase record is found. The purchase record may have been created at “create record event” 320, as noted above. At “polling event” 332, thecommerce platform 108 may respond to polls from the vendor or store, wherein the polling requests information about a status of the purchase. At “mark record as success event” 334, therecord 302 is marked to indicate success or failure of the asynchronous payment process. -
FIG. 4 is a flow diagram showing anexample payment method 400 to perform an e-commerce payment. Atoperation 402, an interface may be exposed to allow it to be called by applications. In the example ofFIG. 1 , the applications programming interface (API) 120 is exposed to allow calls by theoperating system 116. - At
operation 404, a call is received at the interface regarding a purchase transaction from an e-commerce application. In the example ofFIG. 1 , thee-commerce application 118 calls theAPI 120 in the course of performing an e-commerce transaction. - At
operation 406, the purchase transaction is examined to determine if an associated payment method is synchronous or asynchronous. In one example, the payment system and/or provider may provide an indication of whether the transaction is synchronous or asynchronous, thereby allowing the transaction to be handled appropriately. In different example systems, an examination of the transaction may be performed by theAPI 120 or by thecommerce platform 108 to reveal if the purchase transaction is synchronous or asynchronous. In the example ofFIG. 3 , the “confirm purchase event” 318 may return an error, indicating that a synchronous payment method has failed, and that the payment method may be asynchronous. - At
operation 408, a payment system is contacted. Communication with the payment system may result in performance of the purchase transaction. The purchase transaction may be based at least in part on the determination, atoperation 406, distinguishing between synchronous and asynchronous payment methods. - At
operation 410, a result of the purchase transaction is provided to the e-commerce application. -
FIG. 5 is a flow diagram showing an exampleerror handling method 500 to perform an asynchronous payment after failure of a synchronous payment. Atoperation 502, a message (e.g., an error message) is received indicating failure of a transaction. The error may be due to an inability of a system to process a purchase transaction as a synchronous purchase transaction. In the example ofFIG. 3 , an error may be returned by the “confirm purchase event” 318, indicating an error due to an asynchronous payment system. - At
operation 504, the payment system may be determined to be asynchronous. Asynchronous payment systems may be based on multi-step money transfer systems. In one non-limiting example, such payment systems may include those having similarity to Verified by Visa, etc. In such an example, credit cards, which are normally synchronous, may be flagged to need extra authentication, thereby becoming asynchronous. - In an example shown by
operation 506, a user interface may be provided to allow the user to communicate with a payment site associated with the asynchronous payment method. In the example ofFIG. 2 , thepayment collection webpage 210 of the payment collection service (PCS) 202 has wrapped awebpage 212 presented by thepayment system 106. - At
operation 508, a webpage associated with an asynchronous payment system is wrapped within a user interface, which may be provided byAPI 120. In the example ofFIG. 3 , at “load PCS page event” 326 the paymentcollection service webpage 212 from avendor 104 is wrapped by thepayment collection webpage 210, which may be provided by the commerce platform or theAPI 120. - At
operation 510, operation of the user interface may collect data for use by the asynchronous payment system. The data may include user names and/or passwords to allow a money transfer from one or more accounts associated with the asynchronous payment system (e.g., one or more bank accounts used by the asynchronous system). - At
operation 512, a user-facing dialog box may be provided by theAPI 120 until the transaction is completed. The dialog box may assist by approximating the experience the user would have during a synchronous payment process during the current asynchronous process. The dialog box may be any persistent user interface element that prevents user interaction with other portions of the application until the user has taken action on the dialog box itself In such an example, the dialog box or other user interface element persists until the user hits a “continue” or similar button. At that point, if the transaction is still pending, the dialog box may be changed to encourage the user to “try again” or “close” the dialog box, thereby ending the transaction with failure. - At
operation 514, a result of success of failure may be returned to the e-commerce application. In the example ofFIG. 3 , the “mark record as success event” 334 may provide such a result to the e-commerce application. -
FIG. 6 is a flow diagram showing anexample extensibility method 600 to extend a number of payment systems available to e-commerce applications. Atoperation 602, a number of payment systems for which the interface (e.g.,API 120 ofFIG. 1 ) is configured to handle purchase transactions is extended and/or increased. For example, as new payment systems, either synchronous or asynchronous, are introduced and/or incorporated for use, theAPI 120 may be extended to operate with each of them. Thus, the extension of the API may include additional executable statements to handle operation with each of the new payment systems. - At
operation 604, a format, protocol, etc., of calls to the interface may be maintained in an unchanged manner after the extension. Thus, the same calls by thee-commerce application 118 to theAPI 120 may be used in an unchanged manner after the extension, while new calls may additionally be available. -
FIG. 7 is a flow diagram showing anexample cleanup method 700 to perform cleanup in the event of an e-commerce payment failure. Atoperation 702, an exit by a user of an e-commerce application may be detected. For example, the user may exit the e-commerce application or may turn off the client device. This may leave any transaction in a state of uncertainty. - At
operation 704, a cleanup of the purchase transaction is performed. The cleanup may determine if a license has been granted to the user, and may return a status of the purchase transaction to the e-commerce application. - As used herein, “computer-readable media” includes computer storage media and communication media. Computer storage media includes volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer-readable instructions, data structures, program modules, or other data. Computer storage media includes, but is not limited to, random access memory (RAM), read only memory (ROM), electrically erasable programmable ROM (EEPROM), flash memory or other memory technology, compact disk ROM (CD-ROM), digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store information for access by a computing device. In contrast, communication media may embody computer-readable instructions, data structures, program modules, or other data that is defined in a modulated data signal, such as in conjunction with a carrier wave. As defined herein, computer storage media does not include communication media.
- Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as exemplary forms of implementing the claims
Claims (20)
Priority Applications (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/923,284 US20140379558A1 (en) | 2013-06-20 | 2013-06-20 | Extensible Interface for Synchronous and Asynchronous Payment |
EP13771338.4A EP3011512A4 (en) | 2013-06-20 | 2013-09-21 | Extensible interface for synchronous and asynchronous payment |
CN201380077590.1A CN105408925A (en) | 2013-06-20 | 2013-09-21 | Extensible interface for synchronous and asynchronous payment |
PCT/US2013/061081 WO2014204503A1 (en) | 2013-06-20 | 2013-09-21 | Extensible interface for synchronous and asynchronous payment |
US15/649,059 US11301822B2 (en) | 2013-06-20 | 2017-07-13 | Extensible interface for synchronous and asynchronous payment |
US17/707,201 US20220222631A1 (en) | 2013-06-20 | 2022-03-29 | Extensible interface for synchronous and asynchronous payment |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/923,284 US20140379558A1 (en) | 2013-06-20 | 2013-06-20 | Extensible Interface for Synchronous and Asynchronous Payment |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/649,059 Continuation US11301822B2 (en) | 2013-06-20 | 2017-07-13 | Extensible interface for synchronous and asynchronous payment |
Publications (1)
Publication Number | Publication Date |
---|---|
US20140379558A1 true US20140379558A1 (en) | 2014-12-25 |
Family
ID=49293917
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/923,284 Abandoned US20140379558A1 (en) | 2013-06-20 | 2013-06-20 | Extensible Interface for Synchronous and Asynchronous Payment |
US15/649,059 Active 2036-07-03 US11301822B2 (en) | 2013-06-20 | 2017-07-13 | Extensible interface for synchronous and asynchronous payment |
US17/707,201 Pending US20220222631A1 (en) | 2013-06-20 | 2022-03-29 | Extensible interface for synchronous and asynchronous payment |
Family Applications After (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/649,059 Active 2036-07-03 US11301822B2 (en) | 2013-06-20 | 2017-07-13 | Extensible interface for synchronous and asynchronous payment |
US17/707,201 Pending US20220222631A1 (en) | 2013-06-20 | 2022-03-29 | Extensible interface for synchronous and asynchronous payment |
Country Status (4)
Country | Link |
---|---|
US (3) | US20140379558A1 (en) |
EP (1) | EP3011512A4 (en) |
CN (1) | CN105408925A (en) |
WO (1) | WO2014204503A1 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20170068939A1 (en) * | 2015-09-09 | 2017-03-09 | Mastercard International Incorporated | Systems and methods for facilitating cross-platform purchase redirection |
CN109035020A (en) * | 2018-07-13 | 2018-12-18 | 中国银行股份有限公司 | A kind of return method and device of Transaction Information |
US11301822B2 (en) | 2013-06-20 | 2022-04-12 | Microsoft Technology Licensing, Llc | Extensible interface for synchronous and asynchronous payment |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111582847A (en) * | 2020-04-30 | 2020-08-25 | 福州吉诺网络科技有限公司 | Payment method and system |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080010215A1 (en) * | 2006-07-06 | 2008-01-10 | Firethorn Holdings, Llc | Methods and Systems For Managing Payment Sources in a Mobile Environment |
US20100299195A1 (en) * | 2006-04-24 | 2010-11-25 | Robert Nix | Systems and methods for implementing financial transactions |
US20120310826A1 (en) * | 2011-06-03 | 2012-12-06 | Saurav Chatterjee | Virtual wallet card selection apparatuses, methods and systems |
US20130019018A1 (en) * | 2011-07-12 | 2013-01-17 | Bank Of America Corporation | Optimized service integration |
US20130144762A1 (en) * | 2011-04-04 | 2013-06-06 | Google Inc. | Cancelling a Purchasing Request |
US20130246261A1 (en) * | 2011-08-18 | 2013-09-19 | Thomas Purves | Multi-Directional Wallet Connector Apparatuses, Methods and Systems |
US20130339490A1 (en) * | 2012-06-19 | 2013-12-19 | Salesforce.Com, Inc. | Method and system for semi-synchronously exporting data |
US20140006279A1 (en) * | 2012-06-28 | 2014-01-02 | Sap Ag | Consistent Interface for Business Transaction Authorisation Request and Rejected Direct Debits Post Processing Initiation Run |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CA2329895A1 (en) * | 2000-09-19 | 2002-03-19 | Soft Tracks Enterprises Ltd. | Merchant wallet server |
US20020087412A1 (en) * | 2000-10-24 | 2002-07-04 | Fay Wood | Method for post-sales customer retention |
CA2332656A1 (en) * | 2001-01-26 | 2002-07-26 | Certapay Inc. | Online payment transfer and identity management system and method |
US8175938B2 (en) | 2004-04-13 | 2012-05-08 | Ebay Inc. | Method and system for facilitating merchant-initiated online payments |
US8261070B2 (en) * | 2004-04-23 | 2012-09-04 | The Boeing Company | Authentication of untrusted gateway without disclosure of private information |
US8223935B2 (en) | 2005-04-30 | 2012-07-17 | Oracle International Corporation | Revenue management systems and methods |
US7591424B2 (en) * | 2006-03-30 | 2009-09-22 | Microsoft Corporation | Framework for adding billing payment types |
CN101295383A (en) * | 2008-06-25 | 2008-10-29 | 熊刚 | Application method of payment gateway settlement scheme in electronic commerce website |
US20100280909A1 (en) | 2009-04-29 | 2010-11-04 | Microsoft Corporation | Provider-driven payment adapter plug-in to payment gateway |
US8571937B2 (en) | 2010-10-20 | 2013-10-29 | Playspan Inc. | Dynamic payment optimization apparatuses, methods and systems |
KR101207335B1 (en) * | 2010-12-30 | 2012-12-04 | 한국정보통신주식회사 | Settlement apparatus and method using remote user interface |
CN102289753A (en) * | 2011-07-27 | 2011-12-21 | 苏州巴米特信息科技有限公司 | High-security electronic payment method |
CN102609841B (en) * | 2012-01-13 | 2015-02-25 | 东北大学 | Remote mobile payment system based on digital certificate and payment method |
US20140379558A1 (en) * | 2013-06-20 | 2014-12-25 | Microsoft Corporation | Extensible Interface for Synchronous and Asynchronous Payment |
-
2013
- 2013-06-20 US US13/923,284 patent/US20140379558A1/en not_active Abandoned
- 2013-09-21 WO PCT/US2013/061081 patent/WO2014204503A1/en active Application Filing
- 2013-09-21 CN CN201380077590.1A patent/CN105408925A/en not_active Withdrawn
- 2013-09-21 EP EP13771338.4A patent/EP3011512A4/en not_active Withdrawn
-
2017
- 2017-07-13 US US15/649,059 patent/US11301822B2/en active Active
-
2022
- 2022-03-29 US US17/707,201 patent/US20220222631A1/en active Pending
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100299195A1 (en) * | 2006-04-24 | 2010-11-25 | Robert Nix | Systems and methods for implementing financial transactions |
US20080010215A1 (en) * | 2006-07-06 | 2008-01-10 | Firethorn Holdings, Llc | Methods and Systems For Managing Payment Sources in a Mobile Environment |
US20130144762A1 (en) * | 2011-04-04 | 2013-06-06 | Google Inc. | Cancelling a Purchasing Request |
US20120310826A1 (en) * | 2011-06-03 | 2012-12-06 | Saurav Chatterjee | Virtual wallet card selection apparatuses, methods and systems |
US20130019018A1 (en) * | 2011-07-12 | 2013-01-17 | Bank Of America Corporation | Optimized service integration |
US20130246261A1 (en) * | 2011-08-18 | 2013-09-19 | Thomas Purves | Multi-Directional Wallet Connector Apparatuses, Methods and Systems |
US20130339490A1 (en) * | 2012-06-19 | 2013-12-19 | Salesforce.Com, Inc. | Method and system for semi-synchronously exporting data |
US20140006279A1 (en) * | 2012-06-28 | 2014-01-02 | Sap Ag | Consistent Interface for Business Transaction Authorisation Request and Rejected Direct Debits Post Processing Initiation Run |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11301822B2 (en) | 2013-06-20 | 2022-04-12 | Microsoft Technology Licensing, Llc | Extensible interface for synchronous and asynchronous payment |
US20170068939A1 (en) * | 2015-09-09 | 2017-03-09 | Mastercard International Incorporated | Systems and methods for facilitating cross-platform purchase redirection |
US10068213B2 (en) * | 2015-09-09 | 2018-09-04 | Mastercard International Incorporated | Systems and methods for facilitating cross-platform purchase redirection |
CN109035020A (en) * | 2018-07-13 | 2018-12-18 | 中国银行股份有限公司 | A kind of return method and device of Transaction Information |
Also Published As
Publication number | Publication date |
---|---|
US11301822B2 (en) | 2022-04-12 |
EP3011512A4 (en) | 2016-12-28 |
WO2014204503A1 (en) | 2014-12-24 |
US20220222631A1 (en) | 2022-07-14 |
US20170344961A1 (en) | 2017-11-30 |
EP3011512A1 (en) | 2016-04-27 |
CN105408925A (en) | 2016-03-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20220222631A1 (en) | Extensible interface for synchronous and asynchronous payment | |
US20230082253A1 (en) | Digital Wallet | |
US9928358B2 (en) | Methods and systems for using transaction data to authenticate a user of a computing device | |
US8738518B2 (en) | Methods and systems for executing a plurality of money transfers having a fluctuating parameter | |
US20100325042A1 (en) | Payment service to efficiently enable electronic payment | |
US20120158654A1 (en) | Receipt storage in a digital wallet | |
US20160239886A1 (en) | Systems and methods for facilitating user selection events over a network | |
US9652752B2 (en) | Dynamic network timeout tuning | |
CN104520885A (en) | Processing payment information for online orders at local merchant's point of sale | |
US9336549B2 (en) | Systems and methods for performing in-store and online transactions | |
JP6511215B2 (en) | Frame-based implementation for payment widgets | |
US20140095287A1 (en) | System and method for automatic and identifiable coupon redemption | |
US10963883B1 (en) | Vehicle identifier communication and authentication | |
KR20170037445A (en) | Bank server for brokerage of account receivable and method of operation thereof | |
JP6571597B2 (en) | Inheritance support system and inheritance support method | |
KR20160009803A (en) | Apparatus, system and method for integrated management of point | |
KR101569046B1 (en) | Product purchase user interface providing system and providing method thereof | |
US12051069B2 (en) | Web-based order processing system and techniques for processing orders via webpage non-fungible tokens | |
US20240020683A1 (en) | Methods and systems for multiple gating verifications based on a blockchain wallet | |
KR101955713B1 (en) | Computing apparatus and method for providing franchise loan services | |
US20220122059A1 (en) | Prepaid card value redemption | |
US11461761B2 (en) | System for conducting transactions independent of point of sale system | |
US8423061B1 (en) | Initiation of wireless service | |
WO2017007149A1 (en) | Automated payment device and operation method therefor | |
US8682787B1 (en) | Trade-in program with advance payment |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: MICROSOFT CORPORATION, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WASKOM, SARAH;XIAO, HUIYONG;LI, GEORGE;AND OTHERS;SIGNING DATES FROM 20130619 TO 20130620;REEL/FRAME:031035/0011 |
|
AS | Assignment |
Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034747/0417 Effective date: 20141014 Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:039025/0454 Effective date: 20141014 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |