Square
[ALPHA] This provider for Square is in alpha stage. It can not sync products, variants yet nor has it been tested a lot. Use at your own risk. Any feedback is very welcome.
Using the provider
site/config/config.php
<?php
return [
'bnomei.kart.provider' => 'square',
// other options
];
API Credentials
You can create the ACCESS_TOKEN
within the Square developer dashboard. Be sure to start out with using the Sandbox token and set the production one only when going live. You need to provide the credentials for LOCATION_ID
and optionally the API_VERSION
as config values or via an .env
file (plugin).
.env
SQUARE_ACCESS_TOKEN=XXX
SQUARE_LOCATION_ID=ZZZ
# SQUARE_API_VERSION=
Customzing the Checkout
You can use callbacks to customise both the checkout process and each line item. The returned arrays from your callbacks will be merged with the defaults created by the plugin for this provider, allowing you to override those defaults. Check the relevant PHP class and the linked online documentation for the provider to learn more about the expected data structure.
<?php
return [
'bnomei.kart.square.checkout_options' => function (\Bnomei\Kart\Kart $kart) {
// configure the checkout based on current kart instance
// https://developer.squareup.com/reference/square/checkout-api/create-payment-link
return [];
},
'bnomei.kart.square.checkout_line' => function (\Bnomei\Kart\Kart $kart, \Bnomei\Kart\CartLine $line) {
// add custom data to the current checkout line
// https://developer.squareup.com/docs/orders-api/create-orders#create-an-ad-hoc-line-item
return [];
},
// other options
];