Getting Started
The Point of Sale (POS) integration guide includes extensive and reference materials to aid POS system's developers for integrating any POS system with CRM.COM Rewards platform, using a set of recommended Web API methods provided by CRM.COM
CRM.COM Rewards & POS Ecosystem
What is CRM.COM Rewards?
CRM.COM Rewards application is designed to cover any business operations that aim to identify and award their loyal customers, via numerous reward offers. Such offers award loyal customers with conditional (or not) cashback that can be consumed on specific products, units (different merchant' stores), and specific days/hours or at the customer's discretion (with no conditions)
CRM.COM supports two reduction methods that define how the amount that is requested to be consumed (spend) by the customer will be reduced from the total amount that should be paid
- Front-End Reduction - The reduction is done by a front-end system (i.e. POS) by reducing the amount of money that the consumer should actually pay
- Back-End Reduction - The reduction is done is by a back-end system (i.e. PayPal) by letting the customer to pay for the full purchased amount and credit him through a payment gateway system or by generating a refund voucher
What is Point of Sale?
Point of Sale, usually, is the time and place where a retail transaction is completed and the ownership of physical goods is transferred from the seller to the buyer. In the CRM.COM Rewards & POS ecosystem, the POS is more than that, as is a gateway to the loyalty market - enabling merchants to focus on growing and retaining existing customers and provide the additional incentive to repeat customers by awarding their buying behavior
How a POS integration with CRM.COM works
Through this integration guide, we will explain how to integrate a POS system with the CRM.COM using the Front-End Reduction Model. In this model the customer is firstly identified through CRM.COM, then the itemized POS sales transaction is submitted to CRM.COM in order to be awarded while the redemption is done in real time (either automatically or on customer request), resulting to a reduction on the POS for the amount that should be paid
The following diagram illustrates the integration architecture and key integration points
CRM.COM & POS Product Synchronization
What is a CRM.COM Product?
Products are physical goods that can be used by any type of business transaction within CRM.COM software. Products are classified into services and physical goods. They can be sold rented or simply used by customers through multiple business events such as subscriptions, jobs, activities, direct sales and can also be awarded to reward participants through rewards
In addition, Products in CRM.COM have the following attributes that are used to determine their operational characteristics, define trademarks and group products based on common physical characteristics
- Product Type
- Product Brand
- Product Family
- Product Categories
Product Type
Product Type is used to determine the operational characteristics of products, and classify a product as a physical good or a service and what kind of a good or service is (i.e. termed, usage, traceable, non-traceable). For POS integration purposes, all products should have a product type that classifies products as non-traceable physical goods.
Product Brand
Product Brand is used to define trademarks or distinctive names that serve to identify a specific Product or Product line
Product Family
Product Family is used to group products that derive from a common product platform and have similar physical characteristics
Product Categories
Product Categories are used to classify products into generic groups based on specified shared attributes
Putting it all together
Now that we have laid out all product attributes, let's put them together and present a couple examples of Products in CRM.COM
No. | Product | Product Type | Product Brand | Product Family | Product Categories |
---|---|---|---|---|---|
1 | Galaxy Note 9 | Technology | Samsung | Smartphones | Smartphone, Android phone, Octa-core processor |
2 | Samsung MU6070 | Technology | Samsung | QLED TV | TV, QLED, 4K resolution |
3 | Brownie | Chocolates | Yummy Chocolates | Chocolates | Brownie, Chocolate, Diary |
4 | Iced Caramel Latte | Coffee Latte | Coffee Brewers | Coffee Latte | Coffee, Milk, Latte, Syrup |
How Product Synchronization between POS and CRM.COM works
Product Synchronization can be achieved using CRM.COM Web API methods that a POS system can call periodically in order to synchronize products information that exists in the POS with the ones in CRM.COM, resulting into creating new products or update existing ones. Prior product synchronization, the merchant that owns the POS system should map correctly the POS product information with the CRM.COM product information (a suggested mapping was described previously, where we presented the various product attributes)
Before you begin
Prior jumping into the actual implementation, let's walk through a few basic API concepts that will be required on each subsequently method
Authentication
Before performing any logical unit of work, an authentication token must be acquired and subsequently will be used by all other Web API methods in order to access and performed any operations in the system. All API requests must be made using a valid authentication token, otherwise such requests will fail
Acquiring an authentication token can be accomplished by using one of the following methods
- Web API Key
- Username & Password
Authentication Recommended Method
The recommended method of authentication is using Web API Keys of a "System Key" classification. Web API Keys are assigned to specific users in order to access a specific organization and can be used to authenticate users through Web API, resulting to an authentication token that can subsequently be used by other Web API calls, without any data restrictions
The authentication Web API call that should be performed is POST authentication/web_api_key/token (based on HTTP Basic Auth)
Web API Key Method Example
Using Fields Set
CRM.COM Web APIs offer the possibility to select the fields that will be retrieved from each API method by specifying the "fields_set" input parameter. Using such parameter provides the ability to filter the response object and retrieve only the fields that will be used for the implementation. If "fields_set" is not specified, then all fields will be retrieved
Using fields_set Example
Using Pagination
There are some API methods that retrieve a large number of entities, such as list API methods. Some of these CRM.COM API methods provide the option to apply pagination on the results retrieved.
In such cases the API call should be constructed using the following input parameters
- number_of_results: The number of results that can be retrieved through each call. The maximum number of results can be 50, and objects are returned in chronological order (oldest requests are retrieved fist)
- offset: Defines the number of entities that should be skipped from the results. During the first call it should be set to 0 and then it should be increased based on the number of results that were retrieved
Using pagination Example
Integration Scenarios
Purchase and Spend Award Flow
The flow described below is an example of a POS integration with CRM.COM Rewards, including both purchase and spend transactions
Step 1 - Customer Identification | |||
No | Description | Web API Example | POS Conceptual Examples |
---|---|---|---|
1 | The customer is identified on the POS system by providing an identification mean. Such identification can be an email address, a phone number, a card number, etc
Identifying a customer in CRM.COM (also referred as rewards participant) should be performed using the POST rewards_participants/show method The following identification means can be used to identify a customer in CRM.COM
| POST Request https://hostname/crmapi/rest/v2/rewards_participants/show | Prior Customer Identification |
2 | Once a customer is identified in CRM.COM, then the full information of the customer is returned
The following information can be displayed on the POS screen
| After Customer Identification | |
Step 2 - Preview Award and Spend Information (Optional) | |||
No | Description | Web API Example | POS Conceptual Examples |
1 | Prior completing the sales transaction on POS, customer may request to know their available balance and the amount that are eligible to spend on the related transaction. In addition, the preview method will determine whether the purchase customer event that will be submitted can be redeemed by the Front-End System (i.e. POS) or by a Back-End System
Previewing such information should be performed using the POST customer_events/purchases/preview method, and the following information should be passed to CRM.COM
| POST Request https://hostname/crmapi/rest/v2/customer_events/purchases/preview | Not Applicable |
2 | Once a customer is identified in CRM.COM, then the full information of the customer is returned
The following information can be displayed on the POS screen
| After Preview
| |
Step 3 - Submitting Sales Transaction for Awarding Customer | |||
No | Description | Web API Example | POS Conceptual Example |
1 | Once all products are registered in the POS, the sales transaction should be submitted in CRM.COM in the form of a purchase customer event. Creating such customer event, CRM.COM will validate whether the purchased items are eligible to be awarded by a reward offer and credit the customer's wallet balance
Submitting a purchase event in CRM.COM should be performed using the POST customer_events/purchases/create method, and capture the following information
Products should already exist in CRM.COM in order for the POS to make transactions for them. In the event that a POS integration requires to perform transactions for such items, CRM.COM provides the ability to allow such transaction submission using a default product (everything is handled by CRM.COM without additional changes from the POS system) | POST Request https://hostname/crmapi/rest/v2/customer_events/purchases/create | Not Applicable |
2 | Once the sales transaction submission is performed (purchase customer event creation), the POS system can proceed to the redemption step
The following information can be displayed on the POS screen
| After Customer is Awarded | |
Step 4 - Redeem | |||
No | Description | Web API Example | POS Conceptual Example |
1 | Customer may want to spend some of the available wallet amount on the previously created transaction, submitting a spend customer event in CRM.COM
The following information can be displayed on the POS spend request form
Submitting a spend request in CRM.COM should be performed using the POST customer_events/spend_requests/create method, and capture the following information
| POST Request https://hostname/crmapi/rest/v2/customer_events/spend_requests/create | Spend Request Form |
2 | Once the spend request is performed, it will return back the actual amount that was spent, which might be different than the amount that was requested to be spend
The following information will be used in the next step of reducing and closing the sales transactions
| After Spend Request | |
Step 5 - Closing the sales transaction | |||
No | Description | Web API Example | POS Conceptual Example |
1 | Once the sales transaction (purchase customer event) and spend transaction (spend request customer event) are submitted successfully , then the POS system can calculate the redemption amount, reduce it from the total amount of the sales transactions, and close the sales transaction with the customer's payment
The redemption amount is calculated as the sum of the following attributes
The total_spend_amount is also the sum of total_instant_spend_amount, total_additional_spend_amount and total_automatic_spend_amount as retrieved by the "purchases/create" (all these three values are retrieved from the same method as well)
The calculated redemption amount is deducted from the POS sales transaction by applying a discount on the sales transaction
Upon completion, the following information is displayed and printed on the customer's receipt
| Not Applicable | Receipt |
Additional Documentation
Visit CRM.COM Manuals in order to find more information related to the areas / concepts mentioned in above scenarios
Module | Description | Manuals' Link |
---|---|---|
Rewards Participant | Manage the customers who have signed up for Rewards or have been automatically selected to participate | Managing Rewards Participants |
Rewards Participating Merchants | Rewards Participating Merchants are merchants that have a partnership with the business that owns the Rewards platform and can participate in the provided Reward Schemes The Reduction Method that will be used to process the sales it is defined through the Participating Merchant | Managing Rewards Participating Merchants |
Rewards Offers | Reward Offers are used to
| Managing Rewards Offers |
Purchase Customer Events | Events linked with the purchase of goods | Purchase Customer Event |
Spend Request Customer Events | Events linked with the spending of Award points of Participants | Spend Request Customer Event |
Access Tokens | Access Tokens are used to identify and authenticate customers | Managing Access Tokens |
Products | Products are goods that used by business transactions in the System | Managing Products |