End of support notice: On October 30, 2026, AWS will end support for Amazon Pinpoint. After October 30, 2026, you will no longer be able to access the Amazon Pinpoint console or Amazon Pinpoint resources (endpoints, segments, campaigns, journeys, and analytics). For more information, see Amazon Pinpoint end of support. Note: APIs related to SMS, voice, mobile push, OTP, and phone number validate are not impacted by this change and are supported by AWS End User Messaging.
Settings
The Settings resource represents the default settings for an Amazon Pinpoint application. You can use this resource to retrieve information about or update the default settings for an application.
URI
/v1/apps/application-id/settings
HTTP methods
GET
Operation ID: GetApplicationSettings
Retrieves information about the settings for an application.
| Name | Type | Required | Description | 
|---|---|---|---|
| application-id | String | True | The unique identifier for the application. This identifier is displayed as the Project ID on the Amazon Pinpoint console. | 
| Name | Type | Required | Description | 
|---|---|---|---|
| accept | String | False | Indicates which content types, expressed as MIME types, the client understands. | 
| Status code | Response model | Description | 
|---|---|---|
| 200 | ApplicationSettingsResource | The request succeeded. | 
| 400 | MessageBody | The request contains a syntax error (BadRequestException). | 
| 403 | MessageBody | The request was denied because access to the specified resource is forbidden (ForbiddenException). | 
| 404 | MessageBody | The request failed because the specified resource was not found (NotFoundException). | 
| 405 | MessageBody | The request failed because the method is not allowed for the specified resource (MethodNotAllowedException). | 
| 413 | MessageBody | The request failed because the payload for the body of the request is too large (RequestEntityTooLargeException). | 
| 429 | MessageBody | The request failed because too many requests were sent during a certain amount of time (TooManyRequestsException). | 
| 500 | MessageBody | The request failed due to an unknown internal server error, exception, or failure (InternalServerErrorException). | 
PUT
Operation ID: UpdateApplicationSettings
Updates the settings for an application.
| Name | Type | Required | Description | 
|---|---|---|---|
| application-id | String | True | The unique identifier for the application. This identifier is displayed as the Project ID on the Amazon Pinpoint console. | 
| Name | Type | Required | Description | 
|---|---|---|---|
| accept | String | False | Indicates which content types, expressed as MIME types, the client understands. | 
| Status code | Response model | Description | 
|---|---|---|
| 200 | ApplicationSettingsResource | The request succeeded. | 
| 400 | MessageBody | The request contains a syntax error (BadRequestException). | 
| 403 | MessageBody | The request was denied because access to the specified resource is forbidden (ForbiddenException). | 
| 404 | MessageBody | The request failed because the specified resource was not found (NotFoundException). | 
| 405 | MessageBody | The request failed because the method is not allowed for the specified resource (MethodNotAllowedException). | 
| 413 | MessageBody | The request failed because the payload for the body of the request is too large (RequestEntityTooLargeException). | 
| 429 | MessageBody | The request failed because too many requests were sent during a certain amount of time (TooManyRequestsException). | 
| 500 | MessageBody | The request failed due to an unknown internal server error, exception, or failure (InternalServerErrorException). | 
OPTIONS
Retrieves information about the communication requirements and options that are available for the Settings resource.
| Name | Type | Required | Description | 
|---|---|---|---|
| application-id | String | True | The unique identifier for the application. This identifier is displayed as the Project ID on the Amazon Pinpoint console. | 
| Status code | Response model | Description | 
|---|---|---|
| 200 | None | The request succeeded. | 
Schemas
Request bodies
{ "QuietTime": { "Start": "string", "End": "string" }, "Limits": { "Daily": integer, "Total": integer, "Session": integer, "MessagesPerSecond": integer, "MaximumDuration": integer }, "CampaignHook": { "LambdaFunctionName": "string", "WebUrl": "string", "Mode": enum } }
Response bodies
{ "ApplicationId": "string", "LastModifiedDate": "string", "QuietTime": { "Start": "string", "End": "string" }, "Limits": { "Daily": integer, "Total": integer, "Session": integer, "MessagesPerSecond": integer, "MaximumDuration": integer }, "JourneyLimits": { "DailyCap": integer, "TotalCap": integer, "TimeframeCap": { "Days": integer, "Cap": integer } }, "CampaignHook": { "LambdaFunctionName": "string", "WebUrl": "string", "Mode": enum } }
Properties
ApplicationSettingsJourneyLimits
The default sending limits for journeys in the application. To override these limits and define custom limits for a specific journey, use the Journey resource.
| Property | Type | Required | Description | 
|---|---|---|---|
| DailyCap | integer | False | The daily number of messages that an endpoint can receive from all journeys. The maximum value is 100. If set to 0, this limit will not apply. | 
| TimeframeCap | False | The default maximum number of messages that can be sent to an endpoint during the specified timeframe for all journeys. | |
| TotalCap | integer | False | The default maximum number of messages that a single journey can sent to a single endpoint. The maximum value is 100. If set to 0, this limit will not apply. | 
ApplicationSettingsResource
Provides information about an application, including the default settings for an application.
| Property | Type | Required | Description | 
|---|---|---|---|
| ApplicationId | string | True | The unique identifier for the application. This identifier is displayed as the Project ID on the Amazon Pinpoint console. | 
| CampaignHook | False | The settings for the AWS Lambda function to invoke by default as a code hook for campaigns in the application. You can use this hook to customize segments that are used by campaigns in the application. | |
| JourneyLimits | False | The default sending limits for journeys in the application. These limits apply to each journey for the application but can be overridden, on a per journey basis, with the JourneyLimits resource. | |
| LastModifiedDate | string | False | The date and time, in ISO 8601 format, when the application's settings were last modified. | 
| Limits | False | The default sending limits for campaigns in the application. | |
| QuietTime | False | The default quiet time for campaigns in the application. Quiet time is a specific time range when messages aren't sent to endpoints, if all the following conditions are met: 
 If any of the preceding conditions isn't met, the endpoint will receive messages from a campaign or journey, even if quiet time is enabled. | 
CampaignHook
Specifies settings for invoking an AWS Lambda function that customizes a segment for a campaign.
| Property | Type | Required | Description | 
|---|---|---|---|
| LambdaFunctionName | string | False | The name or Amazon Resource Name (ARN) of the AWS Lambda function that Amazon Pinpoint invokes to customize a segment for a campaign. | 
| Mode | string Values:  | False | The mode that Amazon Pinpoint uses to invoke the AWS Lambda function. Possible values are: 
 | 
| WebUrl | string | False | The web URL that Amazon Pinpoint calls to invoke the AWS Lambda function over HTTPS. | 
CampaignLimits
For a campaign, specifies limits on the messages that the campaign can send. For an application, specifies the default limits for messages that campaigns in the application can send.
| Property | Type | Required | Description | 
|---|---|---|---|
| Daily | integer | False | The maximum number of messages that a campaign can send to a single endpoint during a 24-hour period. For an application, this value specifies the default limit for the number of messages that campaigns and journeys can send to a single endpoint during a 24-hour period. The maximum value is 100. | 
| MaximumDuration | integer | False | The maximum amount of time, in seconds, that a campaign can attempt to deliver a message after the scheduled start time for the campaign. The minimum value is 60 seconds. | 
| MessagesPerSecond | integer | False | The maximum number of messages that a campaign can send each second. For an application, this value specifies the default limit for the number of messages that campaigns can send each second. The minimum value is 1. The maximum value is 20,000. | 
| Session | integer | False | The maximum number of messages that the campaign can send per user session. | 
| Total | integer | False | The maximum number of messages that a campaign can send to a single endpoint during the course of the campaign. If a campaign recurs, this setting applies to all runs of the campaign. The maximum value is 100. | 
JourneyTimeframeCap
The number of messages that can be sent to an endpoint during the specified timeframe for all journeys.
| Property | Type | Required | Description | 
|---|---|---|---|
| Cap | integer | False | The maximum number of messages that all journeys can send to an endpoint during the specified timeframe. The maximum value is 100. If set to 0, this limit will not apply. | 
| Days | integer | False | The length of the timeframe in days. The maximum value is 30. If set to 0, this limit will not apply. | 
MessageBody
Provides information about an API request or response.
| Property | Type | Required | Description | 
|---|---|---|---|
| Message | string | False | The message that's returned from the API. | 
| RequestID | string | False | The unique identifier for the request or response. | 
QuietTime
Specifies the start and end times that define a time range when messages aren't sent to endpoints.
| Property | Type | Required | Description | 
|---|---|---|---|
| End | string | False | The specific time when quiet time ends. This value has to use 24-hour notation
                    and be in HH:MM format, where HH is the hour (with a leading zero, if
                    applicable) and MM is the minutes. For example, use  | 
| Start | string | False | The specific time when quiet time begins. This value has to use 24-hour
                    notation and be in HH:MM format, where HH is the hour (with a leading zero, if
                    applicable) and MM is the minutes. For example, use  | 
WriteApplicationSettingsRequest
Specifies the default settings for an application.
| Property | Type | Required | Description | 
|---|---|---|---|
| CampaignHook | False | The settings for the AWS Lambda function to invoke by default as a code hook for campaigns in the application. You can use this hook to customize segments that are used by campaigns in the application. To override these settings and define custom settings for a specific campaign,
                    use the  | |
| Limits | False | The default sending limits for campaigns in the application. To override these limits and define custom limits for a specific campaign or journey, use the Campaign resource or the Journey resource, respectively. | |
| QuietTime | False | The default quiet time for campaigns in the application. Quiet time is a specific time range when messages aren't sent to endpoints, if all the following conditions are met: 
 If any of the preceding conditions isn't met, the endpoint will receive messages from a campaign or journey, even if quiet time is enabled. To override the default quiet time settings for a specific campaign or journey, use the Campaign resource or the Journey resource to define a custom quiet time for the campaign or journey. | 
See also
For more information about using this API in one of the language-specific AWS SDKs and references, see the following: