Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@aurigma/axios-app-farm-api-client
Advanced tools
Axios API Client for App Farm API service of Customer's Canvas web-to-print system.
This module is an Axios API client for App Farm API service which is a part of Customer's Canvas web-to-print system. It is supposed that you are familiar with its services and understand how to use its APIs. To learn more about Customer's Canvas and its services, refer the Getting Started section of its documentation.
The API client is automatically generated with NSwag tool. If for any reasons this API client does not work well for you, feel free to generate it yourself using Swagger document published at Customer's Canvas API Gateway.
To be able to use this package, you need to meet the following requirements:
For other platforms, see the Backend services article in Customer's Canvas documentation.
Install it as a regular npm package:
npm install @aurigma/axios-app-farm-api-client
Receive an access token through your backend as explained in the documentation and deliver it to your app.
const appFarmApiClient = require("@aurigma/axios-app-farm-api-client").AppFarmApiClient;
const axios = require("axios").default;
// You need to create external app in BackOffice with required scopes to receive clientId\clientSecret
// https://customerscanvas.com/dev/getting-started/about-backend-services.html#authorization
const clientId = "";
const clientSecret = "";
const apiUrl = "https://api.customerscanvashub.com/";
const getToken = async (clientId, clientSecret) => {
const requestConfig = {
method: "post",
url: apiUrl + "connect/token",
headers: {
"Content-Type": "application/x-www-form-urlencoded",
},
data: new URLSearchParams({
client_id: clientId,
client_secret: clientSecret,
grant_type: "client_credentials",
}),
};
const response = await axios(requestConfig);
return response.data["access_token"];
};
const token = await getToken(clientId, clientSecret);
And then you can call ApiClients methods with this token:
const config = new appFarmApiClient.ApiClientConfiguration();
config.apiUrl = apiUrl;
config.setAuthorizationToken(token);
const buildInfoClient = new appFarmApiClient.BuildInfoApiClient(config);
const buildInfo = await buildInfoClient.getInfo();
console.log(token);
console.log(buildInfo);
You should retrieve access token from your backend, how it's explained above.
import { AppFarmApiClient } from "@aurigma/axios-app-farm-api-client";
// get token on backend by clientId\clientSecret. Never use clientId\clientSecret on frontend!
// https://customerscanvas.com/dev/getting-started/about-backend-services.html#authorization
const token = "";
const config = new AppFarmApiClient.ApiClientConfiguration();
config.apiUrl = "";
config.setAuthorizationToken(token);
const buildInfoClient = new AppFarmApiClient.BuildInfoApiClient(config)
buildInfoClient.getInfo().then(data => console.log(data));
To find out what other clients are available in this module, refer App Farm API Reference.
NOTE: The class name for each client is formed as ClientNameApiClient, e.g.
BuildInfo
->BuildInfoApiClient
, etc.
FAQs
Axios API Client for App Farm API service of Customer's Canvas web-to-print system.
We found that @aurigma/axios-app-farm-api-client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.