Install the Agent Assist Glue API
Edit on GitHubFollow the steps below to install the Agent Assist feature API.
Prerequisites
To start the feature integration, overview and install the necessary features:
NAME | VERSION | INSTALLATION GUIDE |
---|---|---|
Spryker Core | 202307.0 | Install the Spryker Core Glue API |
Customer Account Management + Agent Assist | 202307.0 | Install the Customer Account Management + Agent Assist feature |
1) Install the required modules
Run the following command to install the required modules:
composer require spryker/agent-auth-rest-api:"^1.0.0" --update-with-dependencies
Ensure that the following module has been installed:
MODULE | EXPECTED DIRECTORY |
---|---|
AgentAuthRestApi | vendor/spryker/agent-auth-rest-api |
2) Set up transfer objects
Run the following command to generate transfer changes:
console transfer:generate
Ensure that the following changes have been applied in the transfer objects:
TRANSFER | TYPE | EVENT | PATH |
---|---|---|---|
RestAgentAccessTokensRequestAttributesTransfer | cell | cell | src/Generated/Shared/Transfer/RestAgentAccessTokensRequestAttributesTransfer |
RestAgentAccessTokensAttributesTransfer | class | created | src/Generated/Shared/Transfer/RestAgentAccessTokensAttributesTransfer |
RestAgentCustomerImpersonationAccessTokensRequestAttributesTransfer | class | created | src/Generated/Shared/Transfer/RestAgentCustomerImpersonationAccessTokensRequestAttributesTransfer |
RestAgentCustomerImpersonationAccessTokensAttributesTransfer | class | created | src/Generated/Shared/Transfer/RestAgentCustomerImpersonationAccessTokensAttributesTransfer |
RestAgentCustomerSearchAttributesTransfer | class | created | src/Generated/Shared/Transfer/RestAgentCustomerSearchAttributesTransfer |
RestAgentCustomerSearchCustomersAttributesTransfer | class | created | src/Generated/Shared/Transfer/RestAgentCustomerSearchCustomersAttributesTransfer |
RestUserTransfer.idAgent | property | created | src/Generated/Shared/Transfer/RestUserTransfer |
CustomerQueryTransfer | class | created | src/Generated/Shared/Transfer/CustomerQueryTransfer |
OauthRequestTransfer | class | created | src/Generated/Shared/Transfer/OauthRequestTransfer |
RestErrorCollectionTransfer | class | created | src/Generated/Shared/Transfer/RestErrorCollectionTransfer |
RestErrorMessageTransfer | class | created | src/Generated/Shared/Transfer/RestErrorMessageTransfer |
OauthAccessTokenValidationRequestTransfer | class | created | src/Generated/Shared/Transfer/OauthAccessTokenValidationRequestTransfer |
CustomerAutocompleteResponseTransfer | class | created | src/Generated/Shared/Transfer/CustomerAutocompleteResponseTransfer |
PaginationTransfer | class | created | src/Generated/Shared/Transfer/PaginationTransfer |
OauthResponseTransfer | class | created | src/Generated/Shared/Transfer/OauthResponseTransfer |
OauthAccessTokenDataTransfer | class | created | src/Generated/Shared/Transfer/OauthAccessTokenDataTransfer |
OauthAccessTokenValidationResponseTransfer | class | created | src/Generated/Shared/Transfer/OauthAccessTokenValidationResponseTransfer |
CustomerTransfer | class | created | src/Generated/Shared/Transfer/CustomerTransfer |
3) Set up behavior
Activate the following plugins:
PLUGIN | SPECIFICATION | PREREQUISITES | NAMESPACE |
---|---|---|---|
AgentRestUserMapperPlugin | Maps Agent data to the Rest user identifier. | None | Spryker\Glue\AgentAuthRestApi\Plugin\AuthRestApi |
AgentAccessTokenRestRequestValidatorPlugin | Validates the access token passed via the X-Agent-Authorization header. |
None | Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication |
AgentRestUserValidatorPlugin | Checks if the RestRequest.restUser is an Agent when an agent-only resource is accessed. |
None | Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication |
AgentAccessTokenRestUserFinderPlugin | Finds the Rest user for the X-Agent-Authorization header. |
None | Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication |
AgentAccessTokensResourceRoutePlugin | Provides the /agent-access-tokens resource route. |
None | Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication |
AgentCustomerImpersonationAccessTokensResourceRoutePlugin | Provides the /agent-customer-impersonation-access-tokens resource route. |
The Customer impersonation grant type must be configured. See the Install the Customer Account Management feature for details. | Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication |
AgentCustomerSearchResourceRoutePlugin | Provides the /agent-customer-search resource route. |
None | Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication |
src/Pyz/Glue/GlueApplication/GlueApplicationDependencyProvider.php
<?php
namespace Pyz\Glue\GlueApplication;
use Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication\AgentAccessTokenRestRequestValidatorPlugin;
use Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication\AgentAccessTokenRestUserFinderPlugin;
use Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication\AgentAccessTokensResourceRoutePlugin;
use Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication\AgentCustomerImpersonationAccessTokensResourceRoutePlugin;
use Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication\AgentCustomerSearchResourceRoutePlugin;
use Spryker\Glue\AgentAuthRestApi\Plugin\GlueApplication\AgentRestUserValidatorPlugin;
use Spryker\Glue\GlueApplication\GlueApplicationDependencyProvider as SprykerGlueApplicationDependencyProvider;
class GlueApplicationDependencyProvider extends SprykerGlueApplicationDependencyProvider
{
/**
* @return \Spryker\Glue\GlueApplicationExtension\Dependency\Plugin\ResourceRoutePluginInterface[]
*/
protected function getResourceRoutePlugins(): array
{
return [
new AgentAccessTokensResourceRoutePlugin(),
new AgentCustomerImpersonationAccessTokensResourceRoutePlugin(),
new AgentCustomerSearchResourceRoutePlugin(),
];
}
/**
* @return \Spryker\Glue\GlueApplicationExtension\Dependency\Plugin\RestRequestValidatorPluginInterface[]
*/
protected function getRestRequestValidatorPlugins(): array
{
return [
new AgentAccessTokenRestRequestValidatorPlugin(),
];
}
/**
* @return \Spryker\Glue\GlueApplicationExtension\Dependency\Plugin\RestUserValidatorPluginInterface[]
*/
protected function getRestUserValidatorPlugins(): array
{
return [
new AgentRestUserValidatorPlugin(),
];
}
/**
* @return \Spryker\Glue\GlueApplicationExtension\Dependency\Plugin\RestUserFinderPluginInterface[]
*/
protected function getRestUserFinderPlugins(): array
{
return [
new AgentAccessTokenRestUserFinderPlugin(),
];
}
}
Ensure that:
-
Invalid agent access tokens passed in the
X-Agent-Authorization
header are rejected with the 401 error code. -
The
X-Agent-Authorization
header is required for/agent-customer-impersonation-access-tokens
and/agent-customer-search
resources. Requests without the header return the 401 error code. -
When a valid agent access token is provided via the
X-Agent-Authorization
, theRestRequest
object in Glue controllers populatesrestUser.idAgent
with the current agent identifier. -
The following resources are available:
RESOURCE | REQUEST TO CHECK |
---|---|
/agent-access-tokens | POST https://glue.mysprykershop.com/agent-access-tokens |
/agent-customer-impersonation-access-tokens | POST https://glue.mysprykershop.com/agent-customer-impersonation-access-tokens |
/agent-customer-search | GET https://glue.mysprykershop.com/agent-customer-search |
src/Pyz/Glue/AuthRestApi/AuthRestApiDependencyProvider.php
<?php
namespace Pyz\Glue\AuthRestApi;
use Spryker\Glue\AgentAuthRestApi\Plugin\AuthRestApi\AgentRestUserMapperPlugin;
use Spryker\Glue\AuthRestApi\AuthRestApiDependencyProvider as SprykerAuthRestApiDependencyProvider;
class AuthRestApiDependencyProvider extends SprykerAuthRestApiDependencyProvider
{
/**
* @return \Spryker\Glue\AuthRestApiExtension\Dependency\Plugin\RestUserMapperPluginInterface[]
*/
protected function getRestUserExpanderPlugins(): array
{
return [
new AgentRestUserMapperPlugin(),
];
}
}
Ensure that, when Authorization
and X-Agent-Authorization
headers are sent, RestRequest.restUser
is populated with Customer and Agent information.
Install related features
Integrate the following related features:
FEATURE | INSTALLATION GUIDE |
---|---|
Customer account management | Install the Customer Account Management feature |
Customer account management + Agent assist | Install the Customer Account Management + Agent Assist feature |
Thank you!
For submitting the form