Create an AWS Marketplace listing
- To gain access to the AWS marketplace management portal, you must be an approved seller by AWS.
- Complete Step 1: Provide product information and Step 2: Configure fulfillment options in the Product Creation Wizard. Metronome does not require specific inputs for these steps, however, you should be aware of the marketplace requirements to post and fulfill your offering.
- Choose the Pricing model for your offering and select Units as the Dimension unit type. Metronome supports Contract with Consumption or Usage-based pricing options. This choice will be tied to the sales motion of your product: Contract with Consumption will have fixed-term lengths while Usage-based pricing products can be started or stopped at any time by your customer. You will need to know the product type when configuring the customer in Metronome.

- 
For products that use the Contract with Consumption model create one or more Contract dimensions tied to the sales motions of your product. These dimensions should correspond to the the different pricing models you have set up in Metronome. They will also be used to manage customer lifecycle events such as subscription end and renewal. This step is not required for Usage-based pricing products.
- Activate pay-as-you-go pricing for additional usage should be unchecked for all dimensions.
- You can select any values you prefer for the API identifier and Display name.
 

- Create a single Usage dimension.
CAUTIONThe API identifier must be called 
usage_fee for the integration to work correctly.
- 
For products that use the Contract with Consumption model, select Single dimension per contract. This step is not required for Usage-based pricing products.
- For Contract duration options , select the duration that best applies to your product.
 

- 
When setting up pricing for your listing, set the price for all contract dimensions to $0.
- For the single usage_feedimension, set the price to $0.01 per unit.
 
- For the single 
CAUTIONDeviating from these values will cause the integration to fail.
Set up IAM credentials for Metronome to meter on your behalf
To make API calls to AWS on your behalf, Metronome needs a role with the right permissions. To set up IAM credentials for Metronome:- In AWS, go to the AWS policy creator.
- 
Create a policy and give it a meaningful name, like MetronomeMarketplacePermissions.
- Specify these permissions:

- In Metronome, go to Connections > Integrations > Available Integrations > AWS Marketplace > click Get started.
- Copy Metronome’s AWS account ID and the unique external ID generated on step 1 of the menu.

- Back in AWS, configure the new AWS role.
- Go to the role creator > Another AWS account.
- Enter Metronome’s AWS account ID and the unique external ID copied from the above step in the External IDfield.
- Leave Require MFA unchecked.
 

- Click Next: Permissions , and under Attach permissions policies , attach the policy you created in step 2.

- Click Next: Tags and add any desired tags. Tags are optional; your AWS Marketplace integration with Metronome works without them.
- 
Click Next: Review and name the role metronome-marketplace.
CAUTIONThe role name must begin with 
metronome-marketplace. To assign different roles for different environments, consider naming those roles something like metronome-marketplace-production, metronome-marketplace-staging.
- 
Add the role’s ARN value in Metronome.
- Find the role’s ARN value in AWS from the newly created role from the roles page. The ARN uses the format arn:aws:iam::<AWS_ACCOUNT_ID>:role/metronome-marketplace.
- Back in Metronome, enter the role’s ARN value in the AWS ARNfield on step 2 of the menu.
 
- Find the role’s ARN value in AWS from the newly created role from the roles page. The ARN uses the format 
- Click Save.
Provision AWS Marketplace customers in Metronome
When a customer agrees to your Marketplace listing, you will need to provision their account in Metronome with a Metronome Contract that reflects the full details of the contract/subscription they signed with you in the Marketplace and AWS identified as the billing provider on that Contract. To connect a customer to AWS and have Metronome begin metering their invoices to AWS on your behalf:- Go to an existing customer’s detail page in Metronome or create a new customer at Customers > Add New Customer.
- Go to Settings > Available Integrations > AWS > Get Started.
- 
Enter the AWS customer ID , product code, and region.
- Unless you’ve specifically chosen a different AWS region, use us-east-1. If you specify the wrong region, you’ll receive an error that the AWS customer cannot be found.
- You can find the product code in the AWS Marketplace Portal for the product you’ve set up.
- The AWS customer ID is included in the token passed to the fulfillment URL associated with your Marketplace product. For details on decoding the token, refer to the AWS documentation and the section on customer setup.
- The Hourly usage-based pricing (per-unit) checkbox must be selected if the product is configured as a “Usage-based pricing ” product in the Marketplace. If this is a contract with consumption product, leave this checkbox unselected.
 
- Unless you’ve specifically chosen a different AWS region, use 
- Create a new contract for the customer that matches the details of the contract they signed with you in the AWS Marketplace. Include any credits and commits the customer has as part of the contract. Learn how to provision contracts in Metronome.
- Under the Billing Configuration section of the configure contract flow, select AWS as the billing provider.
CAUTIONYou cannot add or change the billing provider after creating the contract.
- 
Alternatively, you can use the following endpoints to set up AWS as a customer’s billing provider and assign it to a contract
- 
To set up a new customer configured with AWS Marketplace:
- Call the create customer endpoint
- In the request payload, include customer_billing_provider_configurations:- In the configurationproperty, specifyaws_product_code,aws_customer_id, andaws_region. If the product is configured as a “Usage-based pricing ” product in the Marketplace, also specifyaws_is_subscription_product
 
- In the 
 
- 
To configure an existing customer with AWS Marketplace:
- Call the set customer billing provider configurations endpoint
- In the request payload, include your configuration
- In the configurationproperty, specifyaws_product_code,aws_customer_id, andaws_region. If the product is configured as a “Usage-based pricing ” product in the Marketplace, also specifyaws_is_subscription_product
 
- In the 
 
- 
To set up a new contract with invoices metered to AWS Marketplace:
- Call the create contract endpoint
- In the request payload, include billing_provider_configuration:
 
 
- 
To set up a new customer configured with AWS Marketplace:
What Metronome meters to AWS
When metering to AWS, Metronome sums up a customer’s total amount accrued across all contract invoices that have AWS set as the billing provider since the last metering request. Metronome sets the quantity for each metering record as the total dollar amount expressed in USD cents. If a customer purchased a commit or was offered a credit as part of their contract, Metronome meters like this:- Prepaid commits A contract in Metronome specifies a schedule over which the customer pays for their prepaid commit. Those inputs create one or more scheduled invoices. Metronome meters the amount the customer owes on the prepaid commit on the date associated with the service period of the scheduled invoice, not the created at date.
- Credits As credits on a Metronome contract are not paid for, Metronome only meters overages reflected on invoice totals after the credit has been drawn down in its entirety.
- Postpaid commits Metronome meters usage reflected on invoice totals throughout the duration of the contract. However, if the entirety of the postpaid commit isn’t consumed by the end of the contract, Metronome ignores the true-up invoice and doesn’t send it to the marketplace. This is because the true-up invoice isn’t finalized until after the Metronome grace period ends, at which point the metering endpoint for the marketplace has closed. This means you must handle the true-up in the marketplace directly.
Handling marketplace customer lifecycle events in Metronome and your app
Metronome stops metering if it detects subscription changes due to marketplace lifecycle events, and updates the customer’s status in Metronome accordingly. However, you are responsible for ensuing that the customer’s status is correctly represented in your application and ending the customer’s contract in Metronome, if relevant. To end the customer’s contract in the Metronome app, go to the customer > click the contract > select the overflow menu > click Edit Contract End Date. To end the customer’s contract with the Metronome API, use the/contracts/updateEndDate endpoint.