api/javascript/telnyx-numbers-javascript/SKILL.md
Search for available phone numbers by location and features, check coverage, and place orders. Use when acquiring new phone numbers. This skill provides JavaScript SDK examples.
npx skillsauth add team-telnyx/telnyx-toolkit telnyx-numbers-javascriptInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
npm install telnyx
import Telnyx from 'telnyx';
const client = new Telnyx({
apiKey: process.env['TELNYX_API_KEY'], // This is the default and can be omitted
});
All examples below assume client is already initialized as shown above.
GET /country_coverage
const countryCoverage = await client.countryCoverage.retrieve();
console.log(countryCoverage.data);
GET /country_coverage/countries/{country_code}
const response = await client.countryCoverage.retrieveCountry('US');
console.log(response.data);
Creates an inventory coverage request.
GET /inventory_coverage
const inventoryCoverages = await client.inventoryCoverage.list();
console.log(inventoryCoverages.data);
Gets a paginated list of phone number reservations.
GET /number_reservations
// Automatically fetches more pages as needed.
for await (const numberReservation of client.numberReservations.list()) {
console.log(numberReservation.id);
}
Creates a Phone Number Reservation for multiple numbers.
POST /number_reservations
const numberReservation = await client.numberReservations.create();
console.log(numberReservation.data);
Gets a single phone number reservation.
GET /number_reservations/{number_reservation_id}
const numberReservation = await client.numberReservations.retrieve('number_reservation_id');
console.log(numberReservation.data);
Extends reservation expiry time on all phone numbers.
POST /number_reservations/{number_reservation_id}/actions/extend
const response = await client.numberReservations.actions.extend('number_reservation_id');
console.log(response.data);
Get a paginated list of number orders.
GET /number_orders
// Automatically fetches more pages as needed.
for await (const numberOrderListResponse of client.numberOrders.list()) {
console.log(numberOrderListResponse.id);
}
Creates a phone number order.
POST /number_orders
const numberOrder = await client.numberOrders.create();
console.log(numberOrder.data);
Get an existing phone number order.
GET /number_orders/{number_order_id}
const numberOrder = await client.numberOrders.retrieve('number_order_id');
console.log(numberOrder.data);
Updates a phone number order.
PATCH /number_orders/{number_order_id}
const numberOrder = await client.numberOrders.update('number_order_id');
console.log(numberOrder.data);
Get a paginated list of number block orders.
GET /number_block_orders
// Automatically fetches more pages as needed.
for await (const numberBlockOrder of client.numberBlockOrders.list()) {
console.log(numberBlockOrder.id);
}
Creates a phone number block order.
POST /number_block_orders — Required: starting_number, range
const numberBlockOrder = await client.numberBlockOrders.create({
range: 10,
starting_number: '+19705555000',
});
console.log(numberBlockOrder.data);
Get an existing phone number block order.
GET /number_block_orders/{number_block_order_id}
const numberBlockOrder = await client.numberBlockOrders.retrieve('number_block_order_id');
console.log(numberBlockOrder.data);
Get a list of phone numbers associated to orders.
GET /number_order_phone_numbers
const numberOrderPhoneNumbers = await client.numberOrderPhoneNumbers.list();
console.log(numberOrderPhoneNumbers.data);
POST /number_order_phone_numbers/{id}/requirement_group — Required: requirement_group_id
const response = await client.numberOrderPhoneNumbers.updateRequirementGroup(
'182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',
{ requirement_group_id: '182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e' },
);
console.log(response.data);
Get an existing phone number in number order.
GET /number_order_phone_numbers/{number_order_phone_number_id}
const numberOrderPhoneNumber = await client.numberOrderPhoneNumbers.retrieve(
'number_order_phone_number_id',
);
console.log(numberOrderPhoneNumber.data);
Updates requirements for a single phone number within a number order.
PATCH /number_order_phone_numbers/{number_order_phone_number_id}
const response = await client.numberOrderPhoneNumbers.updateRequirements(
'number_order_phone_number_id',
);
console.log(response.data);
Get a paginated list of sub number orders.
GET /sub_number_orders
const subNumberOrders = await client.subNumberOrders.list();
console.log(subNumberOrders.data);
POST /sub_number_orders/{id}/requirement_group — Required: requirement_group_id
const response = await client.subNumberOrders.updateRequirementGroup(
'182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',
{ requirement_group_id: 'a4b201f9-8646-4e54-a7d2-b2e403eeaf8c' },
);
console.log(response.data);
Get an existing sub number order.
GET /sub_number_orders/{sub_number_order_id}
const subNumberOrder = await client.subNumberOrders.retrieve('sub_number_order_id');
console.log(subNumberOrder.data);
Updates a sub number order.
PATCH /sub_number_orders/{sub_number_order_id}
const subNumberOrder = await client.subNumberOrders.update('sub_number_order_id');
console.log(subNumberOrder.data);
Allows you to cancel a sub number order in 'pending' status.
PATCH /sub_number_orders/{sub_number_order_id}/cancel
const response = await client.subNumberOrders.cancel('sub_number_order_id');
console.log(response.data);
Create a CSV report for sub number orders.
POST /sub_number_orders/report
const subNumberOrdersReport = await client.subNumberOrdersReport.create();
console.log(subNumberOrdersReport.data);
Get the status and details of a sub number orders report.
GET /sub_number_orders/report/{report_id}
const subNumberOrdersReport = await client.subNumberOrdersReport.retrieve(
'12ade33a-21c0-473b-b055-b3c836e1c293',
);
console.log(subNumberOrdersReport.data);
Download the CSV file for a completed sub number orders report.
GET /sub_number_orders/report/{report_id}/download
const response = await client.subNumberOrdersReport.download(
'12ade33a-21c0-473b-b055-b3c836e1c293',
);
console.log(response);
GET /advanced_orders
const advancedOrders = await client.advancedOrders.list();
console.log(advancedOrders.data);
POST /advanced_orders
const advancedOrder = await client.advancedOrders.create();
console.log(advancedOrder.id);
PATCH /advanced_orders/{advanced-order-id}/requirement_group
const response = await client.advancedOrders.updateRequirementGroup(
'182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',
);
console.log(response.id);
GET /advanced_orders/{order_id}
const advancedOrder = await client.advancedOrders.retrieve('182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e');
console.log(advancedOrder.id);
Get a paginated list of inexplicit number orders.
GET /inexplicit_number_orders
// Automatically fetches more pages as needed.
for await (const inexplicitNumberOrderResponse of client.inexplicitNumberOrders.list()) {
console.log(inexplicitNumberOrderResponse.id);
}
Create an inexplicit number order to programmatically purchase phone numbers without specifying exact numbers.
POST /inexplicit_number_orders — Required: ordering_groups
const inexplicitNumberOrder = await client.inexplicitNumberOrders.create({
ordering_groups: [
{
count_requested: 'count_requested',
country_iso: 'US',
phone_number_type: 'phone_number_type',
},
],
});
console.log(inexplicitNumberOrder.data);
Get an existing inexplicit number order by ID.
GET /inexplicit_number_orders/{id}
const inexplicitNumberOrder = await client.inexplicitNumberOrders.retrieve(
'182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',
);
console.log(inexplicitNumberOrder.data);
GET /comments
const comments = await client.comments.list();
console.log(comments.data);
POST /comments
const comment = await client.comments.create();
console.log(comment.data);
GET /comments/{id}
const comment = await client.comments.retrieve('id');
console.log(comment.data);
PATCH /comments/{id}/read
const response = await client.comments.markAsRead('id');
console.log(response.data);
GET /available_phone_number_blocks
const availablePhoneNumberBlocks = await client.availablePhoneNumberBlocks.list();
console.log(availablePhoneNumberBlocks.data);
GET /available_phone_numbers
const availablePhoneNumbers = await client.availablePhoneNumbers.list();
console.log(availablePhoneNumbers.data);
POST /numbers_features — Required: phone_numbers
const numbersFeature = await client.numbersFeatures.create({ phone_numbers: ['string'] });
console.log(numbersFeature.data);
The following webhook events are sent to your configured webhook URL.
All webhooks include telnyx-timestamp and telnyx-signature-ed25519 headers for verification (Standard Webhooks compatible).
| Event | Description |
|-------|-------------|
| numberOrderStatusUpdate | Number Order Status Update |
tools
Build cross-platform VoIP calling apps with React Native using Telnyx Voice SDK. High-level reactive API with automatic lifecycle management, CallKit/ConnectionService integration, and push notifications. Use for mobile VoIP apps with minimal setup.
tools
Build browser-based VoIP calling apps using Telnyx WebRTC JavaScript SDK. Covers authentication, voice calls, events, debugging, call quality metrics, and AI Agent integration. Use for web-based real-time communication.
tools
Build VoIP calling apps on iOS using Telnyx WebRTC SDK. Covers authentication, making/receiving calls, CallKit integration, PushKit/APNS push notifications, call quality metrics, and AI Agent integration. Use when implementing real-time voice communication on iOS.
tools
Build cross-platform VoIP calling apps with Flutter using Telnyx WebRTC SDK. Covers authentication, making/receiving calls, push notifications (FCM + APNS), call quality metrics, and AI Agent integration. Works on Android, iOS, and Web.