Ai telnyx-10dlc-java

install
source · Clone the upstream repo
git clone https://github.com/team-telnyx/ai
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/team-telnyx/ai "$T" && mkdir -p ~/.claude/skills && cp -r "$T/providers/cursor/plugin/skills/telnyx-10dlc-java" ~/.claude/skills/team-telnyx-ai-telnyx-10dlc-java-4b1668 && rm -rf "$T"
manifest: providers/cursor/plugin/skills/telnyx-10dlc-java/SKILL.md
source content
<!-- Auto-generated from Telnyx OpenAPI specs. Do not edit. -->

Telnyx 10DLC - Java

Installation

<!-- Maven -->
<dependency>
    <groupId>com.telnyx.sdk</groupId>
    <artifactId>telnyx</artifactId>
    <version>6.36.0</version>
</dependency>

// Gradle
implementation("com.telnyx.sdk:telnyx:6.36.0")

Setup

import com.telnyx.sdk.client.TelnyxClient;
import com.telnyx.sdk.client.okhttp.TelnyxOkHttpClient;

TelnyxClient client = TelnyxOkHttpClient.fromEnv();

All examples below assume

client
is already initialized as shown above.

Error Handling

All API calls can fail with network errors, rate limits (429), validation errors (422), or authentication errors (401). Always handle errors in production code:

import com.telnyx.sdk.models.messaging10dlc.brand.BrandCreateParams;
import com.telnyx.sdk.models.messaging10dlc.brand.EntityType;
import com.telnyx.sdk.models.messaging10dlc.brand.TelnyxBrand;
import com.telnyx.sdk.models.messaging10dlc.brand.Vertical;
BrandCreateParams params = BrandCreateParams.builder()
    .country("US")
    .displayName("ABC Mobile")
    .email("support@example.com")
    .entityType(EntityType.PRIVATE_PROFIT)
    .vertical(Vertical.TECHNOLOGY)
    .build();
TelnyxBrand telnyxBrand = client.messaging10dlc().brand().create(params);

Common error codes:

401
invalid API key,
403
insufficient permissions,
404
resource not found,
422
validation error (check field formats),
429
rate limited (retry with exponential backoff).

Important Notes

  • Pagination: List methods return a page. Use
    .autoPager()
    for automatic iteration:
    for (var item : page.autoPager()) { ... }
    . For manual control, use
    .hasNextPage()
    and
    .nextPage()
    .

Operational Caveats

  • 10DLC is sequential: create the brand first, then submit the campaign, then attach messaging infrastructure such as the messaging profile.
  • Registration calls are not enough by themselves. Messaging cannot use the campaign until the assignment step completes successfully.
  • Treat registration status fields as part of the control flow. Do not assume the campaign is send-ready until the returned status fields confirm it.

Reference Use Rules

Do not invent Telnyx parameters, enums, response fields, or webhook fields.

Core Tasks

Create a brand

Brand registration is the entrypoint for any US A2P 10DLC campaign flow.

client.messaging10dlc().brand().create()
POST /10dlc/brand

ParameterTypeRequiredDescription
entityType
objectYesEntity type behind the brand.
displayName
stringYesDisplay name, marketing name, or DBA name of the brand.
country
stringYesISO2 2 characters country code.
email
stringYesValid email address of brand support contact.
vertical
objectYesVertical or industry segment of the brand.
companyName
stringNo(Required for Non-profit/private/public) Legal company name.
firstName
stringNoFirst name of business contact.
lastName
stringNoLast name of business contact.
...+16 optional params in references/api-details.md
import com.telnyx.sdk.models.messaging10dlc.brand.BrandCreateParams;
import com.telnyx.sdk.models.messaging10dlc.brand.EntityType;
import com.telnyx.sdk.models.messaging10dlc.brand.TelnyxBrand;
import com.telnyx.sdk.models.messaging10dlc.brand.Vertical;

BrandCreateParams params = BrandCreateParams.builder()
    .country("US")
    .displayName("ABC Mobile")
    .email("support@example.com")
    .entityType(EntityType.PRIVATE_PROFIT)
    .vertical(Vertical.TECHNOLOGY)
    .build();
TelnyxBrand telnyxBrand = client.messaging10dlc().brand().create(params);

Primary response fields:

  • telnyxBrand.brandId
  • telnyxBrand.identityStatus
  • telnyxBrand.status
  • telnyxBrand.displayName
  • telnyxBrand.state
  • telnyxBrand.altBusinessId

Submit a campaign

Campaign submission is the compliance-critical step that determines whether traffic can be provisioned.

client.messaging10dlc().campaignBuilder().submit()
POST /10dlc/campaignBuilder

ParameterTypeRequiredDescription
brandId
string (UUID)YesAlphanumeric identifier of the brand associated with this ca...
description
stringYesSummary description of this campaign.
usecase
stringYesCampaign usecase.
ageGated
booleanNoAge gated message content in campaign.
autoRenewal
booleanNoCampaign subscription auto-renewal option.
directLending
booleanNoDirect lending or loan arrangement
...+29 optional params in references/api-details.md
import com.telnyx.sdk.models.messaging10dlc.campaign.TelnyxCampaignCsp;
import com.telnyx.sdk.models.messaging10dlc.campaignbuilder.CampaignBuilderSubmitParams;

CampaignBuilderSubmitParams params = CampaignBuilderSubmitParams.builder()
    .brandId("BXXXXXX")
    .description("Two-factor authentication messages")
    .usecase("2FA")
    .sampleMessages(java.util.List.of("Your verification code is {{code}}"))
    .build();
TelnyxCampaignCsp telnyxCampaignCsp = client.messaging10dlc().campaignBuilder().submit(params);

Primary response fields:

  • telnyxCampaignCsp.campaignId
  • telnyxCampaignCsp.brandId
  • telnyxCampaignCsp.campaignStatus
  • telnyxCampaignCsp.submissionStatus
  • telnyxCampaignCsp.failureReasons
  • telnyxCampaignCsp.status

Assign a messaging profile to a campaign

Messaging profile assignment is the practical handoff from registration to send-ready messaging infrastructure.

client.messaging10dlc().phoneNumberAssignmentByProfile().assign()
POST /10dlc/phoneNumberAssignmentByProfile

ParameterTypeRequiredDescription
messagingProfileId
string (UUID)YesThe ID of the messaging profile that you want to link to the...
campaignId
string (UUID)YesThe ID of the campaign you want to link to the specified mes...
tcrCampaignId
string (UUID)NoThe TCR ID of the shared campaign you want to link to the sp...
import com.telnyx.sdk.models.messaging10dlc.phonenumberassignmentbyprofile.PhoneNumberAssignmentByProfileAssignParams;
import com.telnyx.sdk.models.messaging10dlc.phonenumberassignmentbyprofile.PhoneNumberAssignmentByProfileAssignResponse;

PhoneNumberAssignmentByProfileAssignParams params = PhoneNumberAssignmentByProfileAssignParams.builder()
    .messagingProfileId("4001767e-ce0f-4cae-9d5f-0d5e636e7809")
    .campaignId("CXXX001")
    .build();
PhoneNumberAssignmentByProfileAssignResponse response = client.messaging10dlc().phoneNumberAssignmentByProfile().assign(params);

Primary response fields:

  • response.messagingProfileId
  • response.campaignId
  • response.taskId
  • response.tcrCampaignId

Webhook Verification

Telnyx signs webhooks with Ed25519. Each request includes

telnyx-signature-ed25519
and
telnyx-timestamp
headers. Always verify signatures in production:

import com.telnyx.sdk.core.UnwrapWebhookParams;
import com.telnyx.sdk.core.http.Headers;

// In your webhook handler (e.g., Spring — use raw body):
@PostMapping("/webhooks")
public ResponseEntity<String> handleWebhook(
    @RequestBody String payload,
    HttpServletRequest request) {
  try {
    Headers headers = Headers.builder()
        .put("telnyx-signature-ed25519", request.getHeader("telnyx-signature-ed25519"))
        .put("telnyx-timestamp", request.getHeader("telnyx-timestamp"))
        .build();
    var event = client.webhooks().unwrap(
        UnwrapWebhookParams.builder()
            .body(payload)
            .headers(headers)
            .build());
    // Signature valid — process the event
    System.out.println("Received webhook event");
    return ResponseEntity.ok("OK");
  } catch (Exception e) {
    System.err.println("Webhook verification failed: " + e.getMessage());
    return ResponseEntity.badRequest().body("Invalid signature");
  }
}

Webhooks

These webhook payload fields are inline because they are part of the primary integration path.

Campaign Status Update

FieldTypeDescription
brandId
stringBrand ID associated with the campaign.
campaignId
stringThe ID of the campaign.
createDate
stringUnix timestamp when campaign was created.
cspId
stringAlphanumeric identifier of the CSP associated with this campaign.
isTMobileRegistered
booleanIndicates whether the campaign is registered with T-Mobile.
type
enum: TELNYX_EVENT, REGISTRATION, MNO_REVIEW, TELNYX_REVIEW, NUMBER_POOL_PROVISIONED, NUMBER_POOL_DEPROVISIONED, TCR_EVENT, VERIFIED
description
stringDescription of the event.
status
enum: ACCEPTED, REJECTED, DORMANT, success, failedThe status of the campaign.

If you need webhook fields that are not listed inline here, read the webhook payload reference before writing the handler.


Important Supporting Operations

Use these when the core tasks above are close to your flow, but you need a common variation or follow-up step.

Get Brand

Inspect the current state of an existing brand registration.

client.messaging10dlc().brand().retrieve()
GET /10dlc/brand/{brandId}

ParameterTypeRequiredDescription
brandId
string (UUID)Yes
import com.telnyx.sdk.models.messaging10dlc.brand.BrandRetrieveParams;
import com.telnyx.sdk.models.messaging10dlc.brand.BrandRetrieveResponse;

BrandRetrieveResponse brand = client.messaging10dlc().brand().retrieve("BXXX001");

Primary response fields:

  • brand.status
  • brand.state
  • brand.altBusinessId
  • brand.altBusinessIdType
  • brand.assignedCampaignsCount
  • brand.brandId

Qualify By Usecase

Fetch the current state before updating, deleting, or making control-flow decisions.

client.messaging10dlc().campaignBuilder().brand().qualifyByUsecase()
GET /10dlc/campaignBuilder/brand/{brandId}/usecase/{usecase}

ParameterTypeRequiredDescription
usecase
stringYes
brandId
string (UUID)Yes
import com.telnyx.sdk.models.messaging10dlc.campaignbuilder.brand.BrandQualifyByUsecaseParams;
import com.telnyx.sdk.models.messaging10dlc.campaignbuilder.brand.BrandQualifyByUsecaseResponse;

BrandQualifyByUsecaseParams params = BrandQualifyByUsecaseParams.builder()
    .brandId("BXXX001")
    .usecase("CUSTOMER_CARE")
    .build();
BrandQualifyByUsecaseResponse response = client.messaging10dlc().campaignBuilder().brand().qualifyByUsecase(params);

Primary response fields:

  • response.annualFee
  • response.maxSubUsecases
  • response.minSubUsecases
  • response.mnoMetadata
  • response.monthlyFee
  • response.quarterlyFee

Create New Phone Number Campaign

Create or provision an additional resource when the core tasks do not cover this flow.

client.messaging10dlc().phoneNumberCampaigns().create()
POST /10dlc/phone_number_campaigns

ParameterTypeRequiredDescription
phoneNumber
string (E.164)YesThe phone number you want to link to a specified campaign.
campaignId
string (UUID)YesThe ID of the campaign you want to link to the specified pho...
import com.telnyx.sdk.models.messaging10dlc.phonenumbercampaigns.PhoneNumberCampaign;
import com.telnyx.sdk.models.messaging10dlc.phonenumbercampaigns.PhoneNumberCampaignCreate;
import com.telnyx.sdk.models.messaging10dlc.phonenumbercampaigns.PhoneNumberCampaignCreateParams;

PhoneNumberCampaignCreate params = PhoneNumberCampaignCreate.builder()
    .campaignId("4b300178-131c-d902-d54e-72d90ba1620j")
    .phoneNumber("+18005550199")
    .build();
PhoneNumberCampaign phoneNumberCampaign = client.messaging10dlc().phoneNumberCampaigns().create(params);

Primary response fields:

  • phoneNumberCampaign.assignmentStatus
  • phoneNumberCampaign.brandId
  • phoneNumberCampaign.campaignId
  • phoneNumberCampaign.createdAt
  • phoneNumberCampaign.failureReasons
  • phoneNumberCampaign.phoneNumber

Get campaign

Inspect the current state of an existing campaign registration.

client.messaging10dlc().campaign().retrieve()
GET /10dlc/campaign/{campaignId}

ParameterTypeRequiredDescription
campaignId
string (UUID)Yes
import com.telnyx.sdk.models.messaging10dlc.campaign.CampaignRetrieveParams;
import com.telnyx.sdk.models.messaging10dlc.campaign.TelnyxCampaignCsp;

TelnyxCampaignCsp telnyxCampaignCsp = client.messaging10dlc().campaign().retrieve("CXXX001");

Primary response fields:

  • telnyxCampaignCsp.status
  • telnyxCampaignCsp.ageGated
  • telnyxCampaignCsp.autoRenewal
  • telnyxCampaignCsp.billedDate
  • telnyxCampaignCsp.brandDisplayName
  • telnyxCampaignCsp.brandId

List Brands

Inspect available resources or choose an existing resource before mutating it.

client.messaging10dlc().brand().list()
GET /10dlc/brand

ParameterTypeRequiredDescription
sort
enum (assignedCampaignsCount, -assignedCampaignsCount, brandId, -brandId, createdAt, ...)NoSpecifies the sort order for results.
page
integerNo
recordsPerPage
integerNonumber of records per page.
...+6 optional params in references/api-details.md
import com.telnyx.sdk.models.messaging10dlc.brand.BrandListPage;
import com.telnyx.sdk.models.messaging10dlc.brand.BrandListParams;

BrandListPage page = client.messaging10dlc().brand().list();

Primary response fields:

  • page.page
  • page.records
  • page.totalRecords

Get Brand Feedback By Id

Fetch the current state before updating, deleting, or making control-flow decisions.

client.messaging10dlc().brand().getFeedback()
GET /10dlc/brand/feedback/{brandId}

ParameterTypeRequiredDescription
brandId
string (UUID)Yes
import com.telnyx.sdk.models.messaging10dlc.brand.BrandGetFeedbackParams;
import com.telnyx.sdk.models.messaging10dlc.brand.BrandGetFeedbackResponse;

BrandGetFeedbackResponse response = client.messaging10dlc().brand().getFeedback("BXXX001");

Primary response fields:

  • response.brandId
  • response.category

Additional Operations

Use the core tasks above first. The operations below are indexed here with exact SDK methods and required params; use references/api-details.md for full optional params, response schemas, and lower-frequency webhook payloads. Before using any operation below, read the optional-parameters section and the response-schemas section so you do not guess missing fields.

OperationSDK methodEndpointUse whenRequired params
Get Brand SMS OTP Status
client.messaging10dlc().brand().getSmsOtpByReference()
GET /10dlc/brand/smsOtp/{referenceId}
Fetch the current state before updating, deleting, or making control-flow decisions.
referenceId
Update Brand
client.messaging10dlc().brand().update()
PUT /10dlc/brand/{brandId}
Inspect the current state of an existing brand registration.
entityType
,
displayName
,
country
,
email
, +2 more
Delete Brand
client.messaging10dlc().brand().delete()
DELETE /10dlc/brand/{brandId}
Inspect the current state of an existing brand registration.
brandId
Resend brand 2FA email
client.messaging10dlc().brand().resend2faEmail()
POST /10dlc/brand/{brandId}/2faEmail
Create or provision an additional resource when the core tasks do not cover this flow.
brandId
List External Vettings
client.messaging10dlc().brand().externalVetting().list()
GET /10dlc/brand/{brandId}/externalVetting
Fetch the current state before updating, deleting, or making control-flow decisions.
brandId
Order Brand External Vetting
client.messaging10dlc().brand().externalVetting().order()
POST /10dlc/brand/{brandId}/externalVetting
Create or provision an additional resource when the core tasks do not cover this flow.
evpId
,
vettingClass
,
brandId
Import External Vetting Record
client.messaging10dlc().brand().externalVetting().imports()
PUT /10dlc/brand/{brandId}/externalVetting
Modify an existing resource without recreating it.
evpId
,
vettingId
,
brandId
Revet Brand
client.messaging10dlc().brand().revet()
PUT /10dlc/brand/{brandId}/revet
Modify an existing resource without recreating it.
brandId
Get Brand SMS OTP Status by Brand ID
client.messaging10dlc().brand().retrieveSmsOtpStatus()
GET /10dlc/brand/{brandId}/smsOtp
Fetch the current state before updating, deleting, or making control-flow decisions.
brandId
Trigger Brand SMS OTP
client.messaging10dlc().brand().triggerSmsOtp()
POST /10dlc/brand/{brandId}/smsOtp
Create or provision an additional resource when the core tasks do not cover this flow.
pinSms
,
successSms
,
brandId
Verify Brand SMS OTP
client.messaging10dlc().brand().verifySmsOtp()
PUT /10dlc/brand/{brandId}/smsOtp
Modify an existing resource without recreating it.
otpPin
,
brandId
List Campaigns
client.messaging10dlc().campaign().list()
GET /10dlc/campaign
Inspect available resources or choose an existing resource before mutating it.None
Accept Shared Campaign
client.messaging10dlc().campaign().acceptSharing()
POST /10dlc/campaign/acceptSharing/{campaignId}
Create or provision an additional resource when the core tasks do not cover this flow.
campaignId
Get Campaign Cost
client.messaging10dlc().campaign().usecase().getCost()
GET /10dlc/campaign/usecase/cost
Inspect available resources or choose an existing resource before mutating it.None
Update campaign
client.messaging10dlc().campaign().update()
PUT /10dlc/campaign/{campaignId}
Inspect the current state of an existing campaign registration.
campaignId
Deactivate campaign
client.messaging10dlc().campaign().deactivate()
DELETE /10dlc/campaign/{campaignId}
Inspect the current state of an existing campaign registration.
campaignId
Submit campaign appeal for manual review
client.messaging10dlc().campaign().submitAppeal()
POST /10dlc/campaign/{campaignId}/appeal
Create or provision an additional resource when the core tasks do not cover this flow.
appealReason
,
campaignId
Get Campaign Mno Metadata
client.messaging10dlc().campaign().getMnoMetadata()
GET /10dlc/campaign/{campaignId}/mnoMetadata
Fetch the current state before updating, deleting, or making control-flow decisions.
campaignId
Get campaign operation status
client.messaging10dlc().campaign().getOperationStatus()
GET /10dlc/campaign/{campaignId}/operationStatus
Fetch the current state before updating, deleting, or making control-flow decisions.
campaignId
Get OSR campaign attributes
client.messaging10dlc().campaign().osr().getAttributes()
GET /10dlc/campaign/{campaignId}/osr/attributes
Fetch the current state before updating, deleting, or making control-flow decisions.
campaignId
Get Sharing Status
client.messaging10dlc().campaign().getSharingStatus()
GET /10dlc/campaign/{campaignId}/sharing
Fetch the current state before updating, deleting, or making control-flow decisions.
campaignId
List shared partner campaigns
client.messaging10dlc().partnerCampaigns().listSharedByMe()
GET /10dlc/partnerCampaign/sharedByMe
Inspect available resources or choose an existing resource before mutating it.None
Get Sharing Status
client.messaging10dlc().partnerCampaigns().retrieveSharingStatus()
GET /10dlc/partnerCampaign/{campaignId}/sharing
Fetch the current state before updating, deleting, or making control-flow decisions.
campaignId
List Shared Campaigns
client.messaging10dlc().partnerCampaigns().list()
GET /10dlc/partner_campaigns
Inspect available resources or choose an existing resource before mutating it.None
Get Single Shared Campaign
client.messaging10dlc().partnerCampaigns().retrieve()
GET /10dlc/partner_campaigns/{campaignId}
Fetch the current state before updating, deleting, or making control-flow decisions.
campaignId
Update Single Shared Campaign
client.messaging10dlc().partnerCampaigns().update()
PATCH /10dlc/partner_campaigns/{campaignId}
Modify an existing resource without recreating it.
campaignId
Get Assignment Task Status
client.messaging10dlc().phoneNumberAssignmentByProfile().retrieveStatus()
GET /10dlc/phoneNumberAssignmentByProfile/{taskId}
Fetch the current state before updating, deleting, or making control-flow decisions.
taskId
Get Phone Number Status
client.messaging10dlc().phoneNumberAssignmentByProfile().listPhoneNumberStatus()
GET /10dlc/phoneNumberAssignmentByProfile/{taskId}/phoneNumbers
Fetch the current state before updating, deleting, or making control-flow decisions.
taskId
List phone number campaigns
client.messaging10dlc().phoneNumberCampaigns().list()
GET /10dlc/phone_number_campaigns
Inspect available resources or choose an existing resource before mutating it.None
Get Single Phone Number Campaign
client.messaging10dlc().phoneNumberCampaigns().retrieve()
GET /10dlc/phone_number_campaigns/{phoneNumber}
Fetch the current state before updating, deleting, or making control-flow decisions.
phoneNumber
Create New Phone Number Campaign
client.messaging10dlc().phoneNumberCampaigns().update()
PUT /10dlc/phone_number_campaigns/{phoneNumber}
Modify an existing resource without recreating it.
phoneNumber
,
campaignId
,
phoneNumber
Delete Phone Number Campaign
client.messaging10dlc().phoneNumberCampaigns().delete()
DELETE /10dlc/phone_number_campaigns/{phoneNumber}
Remove, detach, or clean up an existing resource.
phoneNumber

For exhaustive optional parameters, full response schemas, and complete webhook payloads, see references/api-details.md.