Embedded Apps within the Merchant Dashboard offer a seamless integration experience for both Merchants and Zid Partners. These applications are integrated directly into the dashboard through an iframe, allowing merchants to access and interact with your app without leaving Zid Merchant Dashboard. This approach simplifies the user experience by embedding app functionalities within the familiar environment of the Merchant Dashboard.
The Embedded Apps feature is designed to bypass the standard login procedure for third-party applications. This process is facilitated through a specific authentication flow:
1.
Initial Token Storage: Once a Merchant installs the application, Partners must use designated endpoints to store a token within Zid's system. This token is crucial for the subsequent authentication steps.
2.
Token Transmission: When a Merchant accesses the embedded app, the stored token is sent as a query parameter in the iframe URL. This token serves as an identifier for the Merchant, allowing the Partner's application to recognize and log in the Merchant automatically.
3.
Secure Data Handling: Despite being embedded, the application retains its ability to manage its storage within the browser, including local storage and cookies.
4.
New Scope Requirement: When requesting an embedded page in the Merchant Dashboard, Partners must include the embedded_apps_tokens_write scope in their authorization requests.
5.
Security Recommendations: We recommend our Partners to regularly update tokens and invalidate old ones as a security measure for the Merchant's data integrity.
For the security of embedded applications within the Merchant Dashboard, it's essential to include the following Content-Security-Policy in the HTTP response headers of your app's web pages:
This Content-Security-Policy should be configured in your web server or application framework to ensure that these directives are sent in the HTTP headers of every page that is part of your embedded app.
The expiry of tokens is at the discretion of the Partner, based on their security assessments and requirements. Regular updates to the authorization tokens are recommended.
Partners can update the authentication token for any merchant who has installed their application. This endpoint is used to refresh the token so that the Merchant can retain secure access.Endpoint cURL: