This document will help you in installing Sezzle's Magento 2
extension. This extension is a certified one and listed here in the marketplace. The plugin can also be downloaded from github.
There are two ways of installing and upgrading the extension.
- By composer.
- Manual Process.
- Open terminal and navigate to
Magento
root path. composer require sezzle/sezzlepay
php bin/magento setup:upgrade
php bin/magento setup:di:compile
php bin/magento setup:static-content:deploy
php bin/magento cache:clean
- Download the .zip or tar.gz file from
Sezzle's
github repository. - Unzip the file and follow the following instructions.
- Navigate to
Magento
[Magento]/app/code/
either throughSFTP
orSSH
. - Copy
Sezzle
directory from unzipped folder to[Magento]/app/code/
. - Open the terminal.
- Run the following command to enable
Sezzle
:php bin/magento module:enable Sezzle_Sezzlepay
- Run the
Magento
setup upgrade:php bin/magento setup:upgrade
- Run the
Magento
Dependencies Injection Compile:php bin/`magento` setup:di:compile
- Run the
Magento
Static Content deployment:php bin/magento setup:static-content:deploy
- Login to
Magento
Admin and navigate toSystem > Cache Management
. - Flush the cache storage by selecting
Flush Cache Storage
.
You can now directly navigate from the Configuration Page to get signed up for Sezzle
. To do so, you need to click on Register for Sezzle
which will redirect you to the Sezzle Merchant Signup
Page. If you have the details already, you can simply click on I've already setup Sezzle, I want to edit my settings
to move ahead.
- Open terminal and navigate to
Magento
root path. composer update sezzle/sezzlepay
php bin/magento setup:upgrade
php bin/magento setup:di:compile
php bin/magento setup:static-content:deploy
php bin/magento cache:clean
- Download the .zip or tar.gz file from
Sezzle's
github repository. - Unzip the file and follow the following instructions.
- Copy
Sezzle
directory from unzipped folder to[Magento]/app/code/
. Make sure you are overwriting the files. - Open the terminal.
- Run the following command to enable
Sezzle
:php bin/magento module:enable Sezzle_Sezzlepay
- Run the
Magento
setup upgrade:php bin/magento setup:upgrade
- Run the
Magento
Dependencies Injection Compile:php bin/`magento` setup:di:compile
- Run the
Magento
Static Content deployment:php bin/magento setup:static-content:deploy
- Login to
Magento
Admin and navigate toSystem > Cache Management
. - Flush the cache storage by selecting
Flush Cache Storage
.
- Set
Enabled
asYes
to activate Sezzle as a payment option. - Make sure you have the
Merchant UUID
and theAPI Keys
from theSezzle Merchant Dashboard
. Sign Up if you have not signed up to get the necessities. - Navigate to
Stores > Configuration > Sales > Payment Methods > Sezzle > Payment Settings
in yourMagento
admin. - Set the Payment Mode to
Live
for LIVE and set it asSandbox
for SANDBOX. - Set the
Merchant UUID
,Public Key
andPrivate Key
. - Set
Payment Action
asAuthorize only
for doing payment authorization only andAuthorize and Capture
for doing instant capture. - Set
Min Checkout Amount
to restrict Sezzle payment method below that amount. - Set
Payment from Applicable Countries
toSpecific Countries
. - Set
Payment from Specific Countries
toUnited States
orCanada
as Sezzle is currently available for US and Canada only. - Set
Enable Customer Tokenization
toYes
for allowing Sezzle to tokenize the customer account if they approve it. If customer wish to tokenize their account, next time, they don't have to redirect to Sezzle Checkout for completing the purchase, rather it will happen in your website. - Set
Sort Order
to manage the position of Sezzle in the checkout payment options list. - Save the configuration and clear the cache.
- Set
Enable In-Context Solution
toYes
for the In-Context Checkout to get activated. - Set
In-Context Checkout Mode
toIFrame
orPopUp
depending on how you want Sezzle Checkout to get hosted.
- Set
Enable Settlement Reports
toYes
for the Settlement Reports Dashboard to get activated. - Set
Range
to a value based on which you want to fetch the Settlement Reports. - Set
Enable Automatic Syncing
to fetch the Settlement Reports asynchronously. - Set Schedule and Time of Day for the above automatic sync to run.
Note : Automatic Syncing requires cron to be enabled.
- Set
Enable Widget in PDP
toYes
for adding widget script in the Product Display Page which will help in enablingSezzle Widget
Modal in PDP. - Set
Enable Widget in Cart Page
toYes
for adding widget script in the Cart Page which will help in enablingSezzle Widget
Modal in Cart Page. - Set
Enable Installment Widget in Checkout Page
toYes
if you want to show the Sezzle Installment Widget under Sezzle Payment Option in Checkout Page. - Set
Path to Price Element
. This is the path to the element in the Checkout Page where the order total text value will be detected. - Save the configuration and clear the cache.
- Enable the log tracker to trace the
Sezzle
checkout process. - Set
Send Logs to Sezzle
toYes
if you want the logs to be sent to Sezzle in a periodic basic. For this cron needs to be enabled. - You can also download the latest logs by clicking on
Sezzle Log
if any. - Save the configuration and clear the cache.
- If you have correctly set up
Sezzle
, you will seeSezzle
as a payment method in the checkout page. - Select
Sezzle
and move forward. - Once you click
Continue to Sezzle
orPlace Order
, you will be redirected toSezzle Checkout
to complete the checkout. - In the final page of Sezzle Checkout, check the
Approve {Website Name} to process payments from your Sezzle account for future transactions. You may revoke this authorization at any time in your Sezzle Dashboard
to tokenize your account. And, then click onComplete Order
to complete your purchase. - If your account is already tokenized, order will be placed without redirection otherwise you will be redirected to Sezzle Checkout for completing the purchase.
- On successful order placement, you will be redirected to the order confirmation page.
- If
Payment Action
is set toAuthorize and Capture
, capture will be performed instantly from the extension after order is created and validated inMagento
. - If
Payment Action
is set toAuthorize
, capture needs to be performed manually from theMagento
admin. Follow the below steps to do so.- Go the order and click on
Invoice
. - Verify your input in the
Create Invoice
page and click onSave
to create the invoice. - This will automatically capture the payment in
Sezzle
. - Payment can also be captured via Magento 2 Invoice API.
- Go the order and click on
- Go to
Sales > Orders
in theMagento
admin. - Select the order for which you want to refund the payment.
- Go to Invoices and select the invoice for which you to refund.
- Click on
Credit Memo
and verify your input in theCreate Credit Memo
page. - Save it and the refunded will be initiated in
Sezzle
. - In
Sezzle Merchant Dashboard
,Order Status
asRefunded
means payment has been fully refunded andOrder Status
asPartially Refunded
means payment has been partially refunded. - Payment can also be refunded via Magento 2 Refund API.
- Go to
Sales > Orders
in theMagento
admin. - Select the order for which you want to release the payment.
- Click on
Void
and confirm your action. - In
Sezzle Merchant Dashboard
,Order Status
asDeleted due to checkout not being captured before expiration
means payment has been fully released. - Only Full Release is supported from Magento.
- Payment can also be released via Magento 2 Void API.
- Login to
Magento
admin and navigate toSales > Orders
. - Proceed into the corresponding order.
- If Order Status is
Processing
andTotal Paid
is equals toGrand Total
, payment is successfully captured bySezzle
. - If Order Status is
Pending
andTotal Paid
is not equals toGrand Total
, payment is authorized but yet not captured. - If Order Status is
Closed
, payment is refunded. - If Order Status is
Canceled
, payment is released.
- Login to
Sezzle Merchant Dashboard
and navigate toOrders
. - Proceed into the corresponding order.
- Status as
Approved
means payment is successfully captured bySezzle
. - Status as
Authorized, uncaptured
means payment is authorized but yet not captured. - Status as
Refunded
means payment is refunded. - Status as
Deleted due to checkout not being captured before expiration
means either payment was not captured in time or the payment is released.
- Login to
Magento
admin and navigate toCustomers > All Customers
. - Go inside a customer for which you want to see the tokenization details.
Sezzle
tab will appear if the customer is tokenized.Customer UUID
,Expiration Date
andStatus
will appear.
- Login to
Magento
admin and navigate toReports > Sales > Sezzle Settlement
. - List of the latest Settlement Reports will be shown.
- To make a quick sync, enter the
From
andTo
Date and click onSync
. - Click on
Download
from theAction
column for downloading a Settlement Report. - For viewing the details of a particular Settlement Report, click on
View
fromAction
column. - Settlement Report details can also be downloaded by entering the Settlement Report view.
- Settlement Report can be downloaded via
CSV
orExcel
and Settlement Report Details will be downloaded viaCSV
.
- In the
Sezzle
configuration page of yourMagento
admin, enter theSandbox
API Keys
from yourSezzle Merchant Sandbox Dashboard
and set thePayment Mode
toSandbox
, then save the configuration. Make sure you are doing this on yourdev/staging
website. - On your website, add an item to the cart, then proceed to
Checkout
and selectSezzle
as the payment method. - To pay with Sezzle:
- If customer is not tokenized, click
Continue to Sezzle
. - If customer is tokenized, click
Place Order
. However, if the customer tokenization is expired, Sezzle will create a new checkout on clickingPlace Order
. - If In-Context checkout, click
Pay with Sezzle
.
- If customer is not tokenized, click
- For In-Context checkout, the Sezzle checkout will be hosted in the configured mode,
iFrame
orPopup
. Otherwise, you will be redirected to the Sezzle checkout. - Sign In or Sign Up to continue.
- Enter the payment details using test data, then move to final page.
- Check the
Approve {Website Name} to process payments from your Sezzle account for future transactions. You may revoke this authorization at any time in your Sezzle Dashboard
to tokenize your account. - If your account is already tokenized, order will be placed without redirection otherwise you will be redirected to Sezzle Checkout for completing the purchase.
- After payment is completed at Sezzle, you will be directed to your site's successful payment page.
Sandbox
testing is complete. You can login to yourSezzle Merchant Sandbox Dashboard
to see the test order you just placed.
- There is logging enabled by
Sezzle
for tracing theSezzle
actions. - In case merchant is facing issues which is unknown to
Merchant Success
andSupport
team, they can ask for this logs and forward to thePlatform Integrations
team. - Name of the log will be
sezzlepay.log
.It is always recommended to send thesystem.log
andexception.log
for better tracing of issues.
- Clone the repo.
- Execute
docker-compose up -d --build
to start the Magento server. - Server will be up at
localhost:8085
. If you want to change that, edit thedocker-compose.yml
.
docker exec -it sezzle_magento2 process install
Sezzle will be installed alongside.
docker exec -it sezzle_magento2 process install-sampledata
docker exec -it sezzle_magento2 process upgrade
docker exec -it sezzle_magento2 process compile
docker exec -it sezzle_magento2 process deploy
docker exec -it sezzle_magento2 process developer
docker exec -it sezzle_magento2 process clear
docker-compose down --rmi local -v --remove-orphans