clients/client-marketplace-metering/README.md
AWS SDK for JavaScript MarketplaceMetering Client for Node.js, Browser and React Native.
<fullname>Amazon Web Services Marketplace Metering Service</fullname>
<p>This reference provides descriptions of the low-level Marketplace Metering Service API.</p> <p>Amazon Web Services Marketplace sellers can use this API to submit usage data for custom usage dimensions.</p> <p>For information about the permissions that you need to use this API, see <a href="https://docs.aws.amazon.com/marketplace/latest/userguide/iam-user-policy-for-aws-marketplace-actions.html">Amazon Web Services Marketplace metering and entitlement API permissions</a> in the <i>Amazon Web Services Marketplace Seller Guide.</i> </p> <p> <b>Submitting metering records</b> </p> <p> <i>MeterUsage</i> </p> <ul> <li> <p>Submits the metering record for an Amazon Web Services Marketplace product.</p> </li> <li> <p>Called from: Amazon Elastic Compute Cloud (Amazon EC2) instance or a container running on either Amazon Elastic Kubernetes Service (Amazon EKS) or Amazon Elastic Container Service (Amazon ECS)</p> </li> <li> <p>Supported product types: Amazon Machine Images (AMIs) and containers</p> </li> <li> <p>Vendor-metered tagging: Supported allocation tagging</p> </li> </ul> <p> <i>BatchMeterUsage</i> </p> <ul> <li> <p>Submits the metering record for a set of customers. <code>BatchMeterUsage</code> API calls are captured by CloudTrail. You can use CloudTrail to verify that the software as a subscription (SaaS) metering records that you sent are accurate by searching for records with the <code>eventName</code> of <code>BatchMeterUsage</code>. You can also use CloudTrail to audit records over time. For more information, see the <a href="https://docs.aws.amazon.com/awscloudtrail/latest/userguide/cloudtrail-concepts.html">CloudTrail User Guide</a>.</p> </li> <li> <p>Called from: SaaS applications</p> </li> <li> <p>Supported product type: SaaS</p> </li> <li> <p>Vendor-metered tagging: Supports allocation tagging</p> </li> </ul> <p> <b>Accepting new customers</b> </p> <p> <i>ResolveCustomer</i> </p> <ul> <li> <p>Resolves the registration token that the buyer submits through the browser during the registration process. Obtains a <code>CustomerIdentifier</code> along with the <code>CustomerAWSAccountId</code>, <code>ProductCode</code>, and <code>LicenseArn</code>.</p> </li> <li> <p>Called from: SaaS application during the registration process</p> </li> <li> <p>Supported product type: SaaS</p> </li> <li> <p>Vendor-metered tagging: Not applicable</p> </li> </ul> <p> <b>Entitlement and metering for paid container products</b> </p> <p> <i>RegisteredUsage</i> </p> <ul> <li> <p>Provides software entitlement and metering. Paid container software products sold through Amazon Web Services Marketplace must integrate with the Marketplace Metering Service and call the <code>RegisterUsage</code> operation. Free and Bring Your Own License model (BYOL) products for Amazon ECS or Amazon EKS aren't required to call <code>RegisterUsage</code>. However, you can do so if you want to receive usage data in your seller reports. For more information about using the <code>RegisterUsage</code> operation, see <a href="https://docs.aws.amazon.com/marketplace/latest/userguide/container-based-products.html">Container-based products</a>.</p> </li> <li> <p>Called from: Paid container software products</p> </li> <li> <p>Supported product type: Containers</p> </li> <li> <p>Vendor-metered tagging: Not applicable</p> </li> </ul> <p> <b>Entitlement custom metering for container products</b> </p> <ul> <li> <p>MeterUsage API is available in GovCloud Regions but only supports AMI FCP products in GovCloud Regions. Flexible Consumption Pricing (FCP) Container products aren’t supported in GovCloud Regions: us-gov-west-1 and us-gov-east-1. For more information, see <a href="https://docs.aws.amazon.com/marketplace/latest/userguide/container-based-products.html">Container-based products</a>.</p> </li> <li> <p>Custom metering for container products are called using the MeterUsage API. The API is used for FCP AMI and FCP Container product metering.</p> </li> </ul> <p> <b>Custom metering for Amazon EKS is available in 17 Amazon Web Services Regions</b> </p> <ul> <li> <p>The metering service supports Amazon ECS and EKS for Flexible Consumption Pricing (FCP) products using MeterUsage API. Amazon ECS is supported in all Amazon Web Services Regions that MeterUsage API is available except for GovCloud.</p> </li> <li> <p>Amazon EKS is supported in the following: us-east-1, us-east-2, us-west-1, us-west-2, eu-west-1, eu-central-1, eu-west-2, eu-west-3, eu-north-1, ap-east-1, ap-southeast-1, ap-northeast-1, ap-southeast-2, ap-northeast-2, ap-south-1, ca-central-1, sa-east-1.</p> <note> <p>For questions about adding Amazon Web Services Regions for metering, contact <a href="mailto://aws.amazon.com/marketplace/management/contact-us/">Amazon Web Services Marketplace Seller Operations</a>.</p> </note> </li> </ul>To install this package, use the CLI of your favorite package manager:
npm install @aws-sdk/client-marketplace-meteringyarn add @aws-sdk/client-marketplace-meteringpnpm add @aws-sdk/client-marketplace-meteringThe AWS SDK is modulized by clients and commands.
To send a request, you only need to import the MarketplaceMeteringClient and
the commands you need, for example BatchMeterUsageCommand:
// ES5 example
const { MarketplaceMeteringClient, BatchMeterUsageCommand } = require("@aws-sdk/client-marketplace-metering");
// ES6+ example
import { MarketplaceMeteringClient, BatchMeterUsageCommand } from "@aws-sdk/client-marketplace-metering";
To send a request:
send operation on the client, providing the command object as input.const client = new MarketplaceMeteringClient({ region: "REGION" });
const params = { /** input parameters */ };
const command = new BatchMeterUsageCommand(params);
We recommend using the await operator to wait for the promise returned by send operation as follows:
// async/await.
try {
const data = await client.send(command);
// process data.
} catch (error) {
// error handling.
} finally {
// finally.
}
You can also use Promise chaining.
client
.send(command)
.then((data) => {
// process data.
})
.catch((error) => {
// error handling.
})
.finally(() => {
// finally.
});
The aggregated client class is exported from the same package, but without the "Client" suffix.
MarketplaceMetering extends MarketplaceMeteringClient and additionally supports all operations, waiters, and paginators as methods.
This style may be familiar to you from the AWS SDK for JavaScript v2.
If you are bundling the AWS SDK, we recommend using only the bare-bones client (MarketplaceMeteringClient).
More details are in the blog post on
modular packages in AWS SDK for JavaScript.
import { MarketplaceMetering } from "@aws-sdk/client-marketplace-metering";
const client = new MarketplaceMetering({ region: "REGION" });
// async/await.
try {
const data = await client.batchMeterUsage(params);
// process data.
} catch (error) {
// error handling.
}
// Promises.
client
.batchMeterUsage(params)
.then((data) => {
// process data.
})
.catch((error) => {
// error handling.
});
// callbacks (not recommended).
client.batchMeterUsage(params, (err, data) => {
// process err and data.
});
When the service returns an exception, the error will include the exception information, as well as response metadata (e.g. request id).
try {
const data = await client.send(command);
// process data.
} catch (error) {
const { requestId, cfId, extendedRequestId } = error.$metadata;
console.log({ requestId, cfId, extendedRequestId });
/**
* The keys within exceptions are also parsed.
* You can access them by specifying exception names:
* if (error.name === 'SomeServiceException') {
* const value = error.specialKeyInException;
* }
*/
}
See also docs/ERROR_HANDLING.
Please use these community resources for getting help. We use GitHub issues for tracking bugs and feature requests, but have limited bandwidth to address them.
aws-sdk-js
on AWS Developer Blog.aws-sdk-js.To test your universal JavaScript code in Node.js, browser and react-native environments, visit our code samples repo.
This client code is generated automatically. Any modifications will be overwritten the next time the @aws-sdk/client-marketplace-metering package is updated.
To contribute to client you can check our generate clients scripts.
This SDK is distributed under the Apache License, Version 2.0, see LICENSE for more information.
Command API Reference / Input / Output
</details> <details> <summary> MeterUsage </summary>Command API Reference / Input / Output
</details> <details> <summary> RegisterUsage </summary> </details> <details> <summary> ResolveCustomer </summary> </details>