- Added tax split functionality (#116 thanks @tejpal-mirakl)
- Splitted Tax amount will be transfer to tax connected account
- To enable Tax split configuration for new product order & backlog product order, for new service order & backlog service order You must enter ENABLE_PAYMENT_TAX_SPLIT as true and STRIPE_TAX_ACCOUNT variable must have the stripe tax connected account id in environment
- Insert a new row in account_mapping table manually by entering stripe tax connected account id in stripe_account_id and put 0 in mirakl_shop_id
- Fix seller onboarding checkpoint (#114 thanks @fhervieux)
- Fix rate limit error due to pending debits endpoint for service orders (#113 thanks @fhervieux)
- Fix payment split checkpoint for service orders (#112 thanks @fhervieux)
- Fix: take Mirakl's
order_tax_mode
into account when calculating transfer amounts.
- Bumped dependencies.
- Bumped dependencies.
- Fix URL generation when behind a proxy.
- Bumped dependencies.
- Seller onboarding flow has been migrated from Oauth to Connect Onboarding. Make sure to configure your Connect branding settings before upgrading. You can also disable OAuth for Express accounts in your ’Connect settings.
- Consequently, the
/api/onboarding
endpoint has been removed, theAccountOnboarding
entity has been deleted, and theSTRIPE_CLIENT_ID
environment variable is no longer needed. - The
connector:sync:onboarding
command no longer uses the delay parameter. This parameter is now deprecated, please remove it from your crontab settings. - You can now use the
SCHEME
environment variable to force HTTP when working locally or in a development environment. - The
BASE_HOST
environment variable must now be strictly without the scheme as a prefix, i.e. there must be nohttps://
preceding the domain. - Stripe accounts are now created during the onboarding job and mapped with the corresponding Mirakl shop.
- Auto debit of negative balances is now disabled by default for new Stripe accounts (see #78).
- Improved Controllers tests.
- Fixed the Reason column in alerting emails.
- Fetch orders by id in batches of 100 (#91 thanks @cysp).
- Minor syntax improvements and fixes.
- Added miraklShopId to Stripe Account metadata (#85 thanks @christophersjchow).
- Improved logs readability + added option to output externally via Filebeat.
- Bumped dependencies.
- Added: fetch payment ID from PaymentMapping if not provided in order transaction_number.
- Fixed: mark PaymentMapping as captured if charge is captured.
- Fixed transfers not being created for subscription fees and extra invoices.
- Added migration to restore previously aborted subscription fees and extra invoices to the backlog.
- Bumped dependencies to remove deprecated and abandoned packages.
- Bumped PHPUnit to 9.5.
- Bumped required PHP version to 7.3 or higher.
- Fixed query params formatting for arrays (#72 thanks @fhervieux).
- Fixed serialization of array query params on service endpoints (#70 thanks @fhervieux).
- Fixed: escape
config.key
column name which is a reserved keyword in some DBMSs (#66). - Improve performance in payment split workflow (#67 and #68).
- Fixed: use commercial ID in refund workflow instead of order ID to fetch the payment ID.
- Added: config service to better manage workflows checkpoints.
- Added: "on hold" and "aborted" statuses for better backlog management.
- Added: support for service orders by the payment split and validation workflows.
- Fixed:
account.updated
event will now result in 200 OK if the account is not on Mirakl. - Fixed: captured amount for refused/cancelled orders.
- Breaking changes to the environment variables:
- Default payment metadata key for the payment validation is now
mirakl_commercial_order_id
. The connector will keep using your custom metadata key if you set one. This only affects users relying on the payment validation workflow and with no setMIRAKL_METADATA_ORDER_ID
variable.
- Default payment metadata key for the payment validation is now
- Breaking changes to resources exposed by the connector API:
- Resource: renamed
StripeCharge
entity toPaymentMapping
. - Resource: removed
TRANSFER_INVALID_AMOUNT
status fromStripeTransfer
. - Resource: added
*_ABORTED
and*_ON_HOLD
statuses toStripeTransfer
,StripePayout
andStripeRefund
. - Resource: added
type
toStripeRefund
. - Notification:
stripePayoutId
in thepayout.failed
notification has been deprecated in favor ofpayoutId
. - Notification: added
type
topayout.failed
.
- Resource: renamed
- Fixed capture flow when using PaymentIntents (#46).
- Renamed sequence to match code naming (#45).
- Fixed incorrect method call in webhook controller (#43 thanks @christophersjchow).
- Improve compatibility with hybrid orders in capture flow (#42).
- Fixed payment validation + split combination (#38).
- Prevent failed payouts from being dispatched twice (#40).
- Fetch shops from SERVICE domain too in onboarding job (#31 thanks @fhervieux).
- Added distinct webhooks for operator and sellers (#29).
- Added payment cancellation for orders refused by all sellers (#30).
- Added validation and capture consumers to Docker example.
- Added validation command to Docker example.
- Updated cron schedule for orders in Docker example.
- Updated docker example to force Composer 1.10 (#27).
- Added filter by orderId for transfers API (thanks @daniL16).
- Added payment validation (PA01) workflow.
- Fixed commission handling in refunds workflow.
- Improved retry logic for refunds workflow.
- Improved retry logic for payouts workflow.
- Fixed transfers workflow for new users (thanks @eBusEntwHOFM).
- Bump symfony/http-kernel from 4.4.7 to 4.4.13.
- Improved process-payouts job.
- Fixed rare cases of one cent discrepancy in amount calculation.
- Fixed retry attempts for already created transfers.
- Fixed missing listener for KYC update job.
- Fixed mapping for notifications of FailedRefundMessage.
- Fix test-db messages table handling.
- Retry failed and invalid_amount transfers in process transfers command.
- Moved Docker sample to a new folder for clarity.
- Docker sample is now based on TrafeX/docker-php-nginx.
- Upgrade to Symfony 4.4.7 (LTS).
- Fix PHP requirement to 7.1.
- Add refund capabilities (thanks @ablanchard).
- Fix Transfer amount when order includes taxes.
- Initiation of Stripe Express onboarding.
- Monitoring of Stripe accounts update.
- Transfers from platform Stripe account to sellers Stripe account based on Mirakl Orders.
- Payouts from sellers Stripe account to sellers bank account based on Mirakl Invoices.
- Transfers from sellers Stripe account to platform Stripe account based on Mirakl Invoices (subscriptions fees, etc.).
- Server to server notifications:
- Seller account is updated on Stripe.
- Transfer failed.
- Payout failed.
- Email notifications:
- Server to server notifications fail.
- Daily recap of failed transfers and failed payouts.