Skip to content
유입 & 성장

스마트 발송

결제 완료, 배송 안내처럼 서비스 이용에 필요한 기능성 메시지를 파트너사 서버에서 직접 발송할 때 사용하는 API예요.

BaseURL

https://apps-in-toss-api.toss.im

서버 간 통신에는 mTLS 인증서가 필요해요

스마트 발송 API는 파트너 서버에서 앱인토스 서버로 호출하는 서버 간 통신이에요. 보안을 위해 서버에 mTLS 인증서를 설정한 뒤 호출해 주세요. 인증서 발급 방법은 mTLS 인증서 발급 방법을 참고해 주세요.

API 발송 전 콘솔 설정이 필요해요

API를 호출하기 전에 아래 절차를 먼저 완료해야 해요.

  1. 콘솔에서 기능성 캠페인을 생성하고 템플릿 코드(templateSetCode)를 발급받아요.
  2. 알림 동의문이 필요한 메시지라면 캠페인 생성 전에 알림 동의문을 먼저 만들고, 기능성 캠페인에 연결해야 해요.
  3. 문구 검수 승인을 받아야 해요. 승인 전에는 테스트 메시지도 발송할 수 없어요.

설정 방법은 스마트 발송 소개 문서를 참고해 주세요.


알림 동의문이 필요한 경우

메시지 발송 전 알림 동의문이 필요한지 여부는 메시지 성격에 따라 달라요.

동의문 없이 바로 API를 호출할 수 있는 경우

서비스 이용에 꼭 필요한 정보는 사용자 동의 없이 발송할 수 있어요.

  • 결제 완료, 배송 시작, 배송 완료, 환불 완료
  • 정보 변경 안내, 약관 변경 안내

알림 동의문이 필요한 경우

사용자가 특정 알림을 받겠다고 선택하는 상황에서는 반드시 알림 동의문 요청하기를 통해 동의를 먼저 받아야 해요.

  • 재입고 알림 신청
  • 이벤트 시작 알림 신청
  • 가격 변동 알림 신청
  • 예약 오픈 알림 신청

1. 테스트 메시지 발송하기

콘솔에서 기능성 캠페인을 생성하고 문구 검수 승인을 받은 뒤, 실제 배포 전에 번들이 정상 동작하는지 확인할 때 사용해요.

  • Content-Type: application/json
  • Method: POST
  • URL: /api-partner/v1/apps-in-toss/messenger/send-test-message

요청 헤더

이름타입필수설명
x-toss-user-keystringY사용자를 인증하기 위한 키예요. 사용자 정보 받기를 통해 획득할 수 있어요.

요청 바디

이름타입필수설명
templateSetCodestringY사용할 메시지 템플릿 코드예요. 콘솔에서 등록한 템플릿 코드를 입력해요.
deploymentIdstringY테스트에 사용할 번들 식별값이에요. UUID 형식이며, 콘솔 → 앱 출시에서 업로드한 번들에서 확인할 수 있어요.
contextobjectY템플릿 변수값들이에요. 사용자 이름, 인증번호 등 템플릿에 들어갈 값을 넣어요.
json
{
  "templateSetCode": "ALERT_OTP_TEMPLATE",
  "deploymentId": "019abfe8-fd68-7021-9cdc-30d6053cc009",
  "context": {
    "userName": "홍길동",
    "otp": "123456"
  }
}

성공 응답

이름타입설명
msgCountinteger총 발송된 메시지 수예요.
sentPushCountinteger푸시(Push)로 발송된 메시지 수예요.
sentInboxCountinteger인박스(Inbox)로 발송된 메시지 수예요.
sentSmsCountintegerSMS로 발송된 메시지 수예요.
sentAlimtalkCountinteger알림톡으로 발송된 메시지 수예요.
sentFriendtalkCountinteger친구톡으로 발송된 메시지 수예요.
detailobject전송에 성공한 메시지들의 채널별 상세 목록이에요.
failobject전송에 실패한 메시지들의 채널별 상세 목록이에요.

detail / fail 하위 공통 필드:

이름타입설명
sentPusharray푸시(Push) 채널의 발송 결과 목록이에요.
sentInboxarray인박스(Inbox) 채널의 발송 결과 목록이에요.
sentSmsarraySMS 채널의 발송 결과 목록이에요.
sentAlimtalkarray알림톡 채널의 발송 결과 목록이에요.
sentFriendtalkarray친구톡 채널의 발송 결과 목록이에요.

각 채널 배열의 항목 필드:

이름타입설명
contentIdstring발송된 메시지의 고유 ID예요.
reachedFailReasonstring메시지 도달에 실패한 경우 실패 사유가 담겨 있어요.
json
{
  "resultType": "SUCCESS",
  "success": {
    "msgCount": 1,
    "sentPushCount": 1,
    "sentInboxCount": 0,
    "sentSmsCount": 0,
    "sentAlimtalkCount": 0,
    "sentFriendtalkCount": 0,
    "detail": {
      "sentPush": [{ "contentId": "MSG_ABC123" }],
      "sentInbox": [],
      "sentSms": [],
      "sentAlimtalk": [],
      "sentFriendtalk": []
    },
    "fail": {
      "sentPush": [],
      "sentInbox": [],
      "sentSms": [],
      "sentAlimtalk": [],
      "sentFriendtalk": []
    }
  }
}

실패 응답

json
{
  "resultType": "FAIL",
  "error": {
    "errorCode": "INVALID_PARAMETER",
    "reason": "요청에 실패했습니다."
  }
}
HTTP 상태 코드설명
400요청이 잘못됐거나 필요한 정보가 누락됐어요.
401인증되지 않은 사용자예요.
403메시지를 전송할 권한이 없어요.

2. 메시지 발송하기

특정 사용자 1명에게 기능성 메시지를 발송해요.
문구 검수 승인 후 파트너사 서버에서 원하는 시점에 직접 호출할 수 있어요.

  • Content-Type: application/json
  • Method: POST
  • URL: /api-partner/v1/apps-in-toss/messenger/send-message

호출 제한

userKey별로 분당 최대 10회까지 호출할 수 있어요. 초과 시 에러가 반환돼요.


요청 헤더

이름타입필수설명
x-toss-user-keystringY사용자를 인증하기 위한 키예요. 사용자 정보 받기를 통해 획득할 수 있어요.

요청 바디

이름타입필수설명
templateSetCodestringY사용할 메시지 템플릿 코드예요. 콘솔에서 등록한 템플릿 코드를 입력해요.
contextobjectY템플릿 변수값들이에요. 사용자 이름, 인증번호 등 템플릿에 들어갈 값을 넣어요.
json
{
  "templateSetCode": "ALERT_OTP_TEMPLATE",
  "context": {
    "userName": "홍길동",
    "otp": "123456"
  }
}
curl --location 'https://apps-in-toss-api.toss.im/api-partner/v1/apps-in-toss/messenger/send-message' \
--header 'Content-Type: application/json' \
--header 'x-toss-user-key: {{userKey}}' \
--data '{
  "templateSetCode": "ALERT_OTP_TEMPLATE",
  "context": {
    "userName": "홍길동",
    "otp": "123456"
  }
}'

성공 응답

응답 구조는 테스트 메시지 발송하기와 동일해요.

json
{
  "resultType": "SUCCESS",
  "success": {
    "msgCount": 1,
    "sentPushCount": 1,
    "sentInboxCount": 0,
    "sentSmsCount": 0,
    "sentAlimtalkCount": 0,
    "sentFriendtalkCount": 0,
    "detail": {
      "sentPush": [{ "contentId": "MSG_ABC123" }],
      "sentInbox": [],
      "sentSms": [],
      "sentAlimtalk": [],
      "sentFriendtalk": []
    },
    "fail": {
      "sentPush": [],
      "sentInbox": [],
      "sentSms": [],
      "sentAlimtalk": [],
      "sentFriendtalk": []
    }
  }
}

실패 응답

json
{
  "resultType": "FAIL",
  "error": {
    "errorCode": "INVALID_PARAMETER",
    "reason": "요청에 실패했습니다."
  }
}
HTTP 상태 코드설명
400요청이 잘못됐거나 필요한 정보가 누락됐어요.
401인증되지 않은 사용자예요.
403메시지를 전송할 권한이 없어요.

3. 대량 메시지 발송하기

여러 사용자에게 동일한 기능성 메시지 템플릿으로 한 번에 발송해요.
50건 이상의 발송에 사용하며, 한 번 요청 시 최대 2,500건까지 발송할 수 있어요.

  • Content-Type: application/json
  • Method: POST
  • URL: /api-partner/v1/apps-in-toss/messenger/send-bulk-message

요청 바디

이름타입필수설명
templateSetCodestringY사용할 메시지 템플릿 코드예요. 콘솔에서 등록한 템플릿 코드를 입력해요.
contextListarrayY메시지를 받을 사용자 목록이에요. 최소 1건, 최대 2,500건까지 가능해요.

contextList 항목 필드:

이름타입필수설명
userKeyintegerY사용자의 고유 식별자예요.
contextobjectY템플릿 변수값들이에요. 사용자 이름, 인증번호 등 템플릿에 들어갈 값을 넣어요.
json
{
  "templateSetCode": "ALERT_OTP_TEMPLATE",
  "contextList": [
    {
      "userKey": 12345678,
      "context": {
        "userName": "홍길동",
        "otp": "123456"
      }
    },
    {
      "userKey": 87654321,
      "context": {
        "userName": "김철수",
        "otp": "654321"
      }
    }
  ]
}
curl --location 'https://apps-in-toss-api.toss.im/api-partner/v1/apps-in-toss/messenger/send-bulk-message' \
--header 'Content-Type: application/json' \
--data '{
  "templateSetCode": "ALERT_OTP_TEMPLATE",
  "contextList": [
    {
      "userKey": 12345678,
      "context": { "userName": "홍길동", "otp": "123456" }
    },
    {
      "userKey": 87654321,
      "context": { "userName": "김철수", "otp": "654321" }
    }
  ]
}'

성공 응답

응답 구조는 테스트 메시지 발송하기와 동일해요.

json
{
  "resultType": "SUCCESS",
  "success": {
    "msgCount": 2,
    "sentPushCount": 2,
    "sentInboxCount": 0,
    "sentSmsCount": 0,
    "sentAlimtalkCount": 0,
    "sentFriendtalkCount": 0,
    "detail": {
      "sentPush": [{ "contentId": "MSG_ABC123" }, { "contentId": "MSG_DEF456" }],
      "sentInbox": [],
      "sentSms": [],
      "sentAlimtalk": [],
      "sentFriendtalk": []
    },
    "fail": {
      "sentPush": [],
      "sentInbox": [],
      "sentSms": [],
      "sentAlimtalk": [],
      "sentFriendtalk": []
    }
  }
}

4. 알림 동의문 요청하기 (requestNotificationAgreement)

지원환경: React NativeReact Native SDKv2.5.0WebViewWebView SDKv2.5.0
실행환경: Toss AppSandbox App

requestNotificationAgreement는 스마트 발송의 기능성 메시지를 보내기 전, 사용자에게 알림 수신 동의 UI를 요청하는 함수예요.

사용자가 특정 알림을 받겠다고 선택하는 상황에서는 반드시 동의를 먼저 받아야 해요.
동의 결과는 onEvent 콜백으로 전달되며, 결과에 따라 알림 발송 여부를 결정할 수 있어요.

알림 동의문 등록이 필요해요

개발 전에 아래 절차를 먼저 완료해야 해요.

  1. 알림 동의문을 생성해요.
  2. 기능성 캠페인을 생성하고 등록한 알림 동의문을 연결해요.
  3. 문구 검수 승인을 받으면 등록한 기능성 캠페인의 템플릿 코드를 사용할 수 있어요.
  4. 이 템플릿 코드를 templateCode로 전달해요.

설정 방법은 스마트 발송 소개 문서를 참고해 주세요.


시그니처

typescript
function requestNotificationAgreement(params: RequestNotificationAgreementOptions): () => void;

파라미터

  • params필수

    알림 동의 요청에 사용하는 파라미터예요. 자세한 타입은 아래 RequestNotificationAgreementOptions를 참고하세요.

반환값

  • () => void

    앱브릿지 cleanup 함수를 반환해요. 동의 결과를 받은 후에는 반드시 이 함수를 호출해서 리소스를 해제해야 해요.

예제

tsx
import { requestNotificationAgreement } from '@apps-in-toss/web-framework';

function NotificationAgreementButton() {
  const handleRequestAgreement = () => {
    const cleanup = requestNotificationAgreement({
      options: {
        templateCode: 'your-template-code',
      },
      onEvent: ({ type }) => {
        if (type === 'newAgreement') {
          console.log('알림 수신에 동의했어요.');
        } else if (type === 'alreadyAgreed') {
          console.log('이미 동의된 상태예요.');
        } else if (type === 'agreementRejected') {
          console.log('알림 수신을 거부했어요.');
        }
        cleanup();
      },
      onError: (error) => {
        console.error('알림 동의 요청에 실패했어요:', error);
        cleanup();
      },
    });
  };

  return <button onClick={handleRequestAgreement}>알림 받기</button>;
}
tsx
import { Button } from 'react-native';
import { requestNotificationAgreement } from '@apps-in-toss/framework';

function NotificationAgreementButton() {
  const handleRequestAgreement = () => {
    const cleanup = requestNotificationAgreement({
      options: {
        templateCode: 'your-template-code',
      },
      onEvent: ({ type }) => {
        if (type === 'newAgreement') {
          console.log('알림 수신에 동의했어요.');
        } else if (type === 'alreadyAgreed') {
          console.log('이미 동의된 상태예요.');
        } else if (type === 'agreementRejected') {
          console.log('알림 수신을 거부했어요.');
        }
        cleanup();
      },
      onError: (error) => {
        console.error('알림 동의 요청에 실패했어요:', error);
        cleanup();
      },
    });
  };

  return <Button title="알림 받기" onPress={handleRequestAgreement} />;
}

RequestNotificationAgreementOptions

requestNotificationAgreement 함수에 전달하는 파라미터 타입이에요.

typescript
interface RequestNotificationAgreementOptions {
  options: {
    templateCode: string;
  };
  onEvent: (result: { type: NotificationAgreementResult }) => void;
  onError: (error: unknown) => void | Promise<void>;
}
  • options필수

    알림 동의 요청에 사용할 옵션 객체예요.

    • options.templateCode필수

      알림 동의문이 연결된 기능성 캠페인의 템플릿 코드예요. 콘솔에서 등록한 템플릿 코드를 입력해 주세요.

  • onEvent필수

    동의 결과가 확정됐을 때 실행되는 콜백이에요. NotificationAgreementResult 타입의 type 값이 전달돼요.

  • onError필수

    예기치 않은 에러가 발생했을 때 실행되는 콜백이에요. 에러 객체는 타입이 unknown이에요.

NotificationAgreementResult

onEvent 콜백으로 전달되는 동의 결과 타입이에요.

typescript
type NotificationAgreementResult = 'newAgreement' | 'alreadyAgreed' | 'agreementRejected';
설명
newAgreement사용자가 새로 동의를 완료한 경우예요.
alreadyAgreed이미 동의된 상태로, 추가 동의 없이 결과가 반환된 경우예요.
agreementRejected사용자가 동의를 거부한 경우예요.

참고사항

  • onEvent 또는 onError 콜백에서 반환된 cleanup 함수를 반드시 호출해 주세요.
  • 동일 컴포넌트에서 함수를 재호출하기 전에 이전 cleanup을 먼저 실행해 주세요. 그렇지 않으면 이전 이벤트 리스너가 중복으로 남아 있을 수 있어요.
  • 알림 동의문 등록 방법과 기능성 메시지 발송 흐름은 스마트 발송 소개 문서를 참고해 주세요.
  • 사용자 동의 후 메시지를 발송하려면 파트너사 서버에서 메시지 발송하기를 호출해 주세요.
  • 사용자는 토스 앱 → 전체 탭 → 설정 버튼 → 알림 → 서비스별 알림에서 알림 수신 여부를 직접 제어할 수 있어요.