Skip to content

Latest commit

 

History

History
192 lines (133 loc) · 12.3 KB

File metadata and controls

192 lines (133 loc) · 12.3 KB

Orderdesk DataStore Integration

This Foxy.io-OrderDesk DataStore integration provides you with:

  • a pre-payment webhook to validate transactions prices and quantities.
  • a transaction webhook to update OrderDesk when a transaction is created.

What does it do?

tldr; This OrderDesk DataStore integration will allow you to check your inventory in OrderDesk right before a purchase is completed, and update your inventory right after.

Pre-payment webhook for OrderDesk

This webhook assumes you are using OrderDesk to manage your inventory and product prices.

It provides you with a function to validate the price and quantity submitted to FoxyCart right before a payment is made, thus providing security against HTML modifications in the client side.

  • It validates the cart just before payment to ensure the order is bellow inventory and that the price was not changes in the client side.
  • It validates the prices of all products in a purchase.

You control what messages are displayed to the users if the validation is not successful.

You control what should happen if the webhook itself fails.

Please, notice that it ignores existing subscriptions.

  • if a subscription start date is the current one, price will be checked. If it is in the past, the price is not checked.

Limitations

  • It does not handle discounts.
  • It does not handle item options, such as price_mod.

Setup

Setup Overview

Here are the steps you'll have to take to set up this integration:

  1. Grab your OrderDesk credentials
  2. Grab your Foxy.io credentials:
  3. Deploy your Webhook to your server.
  4. Configure your prepayment webhook using your endpoint.
  5. Go to your Foxy.io store payments page and enable custom pre-payment hook.

Setup Tutorial

Please, note that if you are already using other functions from this repository, there are some steps you may skip (those you've already done).

  1. Grab your OrderDesk credentials
    • Visit https://orderdesk.com and click on the Login button.
    • On your Dashboard
    • Click the "Store Settings" link in the left sidebar
    • Click the "API" tab (it's the rightmost tab)
    • You will find your Store Id and your API key. You will need to copy these to configure your webhook.
  2. Grab your Foxy.io credentials:
    • Go to your Foxy.io store integrations page and create a JSON Webhook integration.
    • Get your Foxy.io Client credentials.
  3. Deploy your Webhook to your Netlify server.
    • Fork this repository (use the button on the top-right corner)
    • Go to your Netlify account and click "New site from Git"
    • Choose "GitHub"
    • Choose the repository you've just cloned
    • You may accept the other values as they are and click "Deploy site"
    • Click "Site settings"
    • On the right sidebar, click "Build & deploy".
    • Click "Environment"
    • Click "Edit variables"
    • Refer to "Configuration" section bellow to create your environment variables.
  4. Configure your prepayment webhook using your endpoint. You may check the docs here: https://wiki.foxycart.com/v/2.0/pre_payment_webhook
    • In Netlify, within your site (webhook) page, click the "Functions" link in the horizontal menu at the top.
      • If you don't see a list of functions that includes "datastore-integration-orderdesk" click the "Site Overview" link and then click the "Functions" link again.
    • Click the "datastore-integration-orderdesk" link.
    • Copy the "Endpoin" URL (you can simply click the copy button for that).
    • Go to your Foxy.io Admin page
    • Under "Store", click on the "Payments" link
    • Look for the "Custom Webhooks" section and check "enable custom pre-payment hook".
    • Paste the endpoint you copied in the "pre-payment hook url" field.
    • Choose how you want to handle possible errors in the webhook (approving or rejecting the transaction). Please note that your customer cannot in any way be responsible for any such error.
    • Save your settings clicking on the "Update Payment Gateway" button in the bottom of the page.
  5. Configure your transaction/created webhook if you want it to update your inventory in OrderDesk. You may check the docs here: https://wiki.foxycart.com/v/2.0/webhooks
    • Go to your Foxy.io Admin page
    • Under "Account", click ["integrations]"(https://admin.foxycart.com/admin.php?ThisAction=AddIntegration)
    • Check the "JSON Webhook" box and paste the same Endpoint you copied from your Netlify function in the URL field.
    • Give it a title that makes sense to you.
    • Copy the value from the "Encryption Key" field.
    • Go to your Netlify dashboard again to add new Environment variables
    • Add the FOXY_WEBHOOK_ENCRYPTION_KEY variable with the Encryption Key you've just copied.
    • You also need to set a value to FOXY_SKIP_INVENTORY_UPDATE_CODES because the default is not to update any inventory in OrderDesk. Set it to any value that does not occur as a code if you don't wish it to skip any inventory update.

Configuration Reference

There are some customization you can do to your webhook. These are set with environment variables that you can set directly in Netlify dashboard.

To configure your environment variables follow these steps:

  • go to your site admin dashboard in Netlify
  • click "Site settings" button
  • click the "Build & deploy" tab in the left menu
  • under Environment, click "Edit variables"

Please, notice that the default values were chosen to match the default OrderDesk settings. You shouldn't need to change these values unless you are not using OrderDesk default fields.

This section contains all possible customizations you can do by setting environment variables.

After changing your environment variables you may want to redeploy your webhook.

Environment variables

These environment variables are used to allow your webhook to authenticate authenticate with Foxy and OrderDesk.

Variable Default Value Description
FOXY_WEBHOOK_ENCRYPTION_KEY "" Optional Your wehook encryption key. This value must not be shared or made public.
FOXY_ORDERDESK_API_KEY "" Required Your OrderDesk API Key
FOXY_ORDERDESK_STORE_ID "" Required Your OrderDesk Store id
Price and Inventory verification

These environment variables are used to configure how the price and inventory verification will work.

You can skip some items from either verification.

Variable Default Value Example config Description
FOXY_SKIP_PRICE_CODES "" "SHIRT-123, PANTS-456" A comma separated list of code values (this is the value set in your 'sku' field in OrderDesk). The items with these codes will skip price verification. You can set this field to ALL in order to skip all price verification.
FOXY_SKIP_INVENTORY_CODES "" "SHIRT-123, PANTS-456" A comma separated list of code values. The items with these codes will skip inventory verification. You can set this field to ALL in order to skip all inventory verification.
FOXY_SKIP_INVENTORY_UPDATE_CODES "__ALL__" "SHIRT-123, PANTS-456" A comma separated list of code values. The items with these codes will skip inventory verification. You can set this field to ALL in order to skip all inventory verification.

If necessary you may change the fields the webhook will consider from OrderDesk. This is likely unnecessary and you shouldn't change these default values unless you are not using OrderDesk default fields.

Variable Default Value Example config Description
FOXY_FIELD_CODE "sku" "code" The name of the field that stores the code in OrderDesk. There is no need to set this if you are using OrderDesk "code" as your "sku".
FOXY_FIELD_PRICE "price" "value" The name of the field that stores the price in the OrderDesk. There is no need to set this if you are using OrderDesk "price" field.
FOXY_FIELD_INVENTORY "stock" "inventory" The name of the field that stores the inventory in OrderDesk. There is no need to set this if you are using OrderDesk "stock" field.
Error messages

You may want to customize the error message displayed for your costumers when a pre-payment error occurs:

To set up custom error messages, simply create new variables as described above. Here are the possible variables:

Variable Default Value Description
FOXY_ERROR_INSUFFICIENT_INVENTORY "Insufficient inventory for these items:" Occurs when the quantity purchased is greater than the inventory available in Orderdesk. A comma separated list of the names of the products out-of-stock will be appended to the end of the error message.
FOXY_ERROR_PRICE_MISMATCH "Prices do not match." Occurs when the price of any of the products does not match with the price field in OrderDesk.

Deploy your webhook

These are instructions for deploying the webhook to Netlify.

You may use the Deploy to Netlify button or use the fork method bellow.

Forking the repository

First: clone this repository

Click the fork button in the top right corner.

Cloning the repository will create your own copy of this Webhook, allowing you to both customize it if you wish and to merge upgrades as they are published.

Second: create a new Netlify Site

Go to your Netlify account and click the "New site from Git" button.

  • Choose your repository.
  • Click the "Advanced" button add the following variables.
    • FOXY_ORDERDESK_API_KEY
    • FOXY_ORDERDESK_STORE_ID
  • To get these variables go to OrderDesk settings, at the 'API' tab.

Upgrade your webhook

If you used the deploy to Netlify Button to deploy, you can simply redo that process.

If you are familiar with Git, you can merge the new version into your repository.

If you forked the repository, you can use the GitHub Action available in the "Actions" tab in your repository to upgrade your Webhook.

  • Click the "Actions" tab. Agree to use GitHub Actions.
  • Click the SyncFork workflow and then "run workflow"

If you've made customizations, there may be conflicts. In this case you par pull the changes and resolve the conflicts manually.