telnyx-numbers-python
npx skills add https://github.com/team-telnyx/telnyx-ext-agent-skills --skill telnyx-numbers-python
Agent 安装分布
Skill 文档
Telnyx Numbers – Python
Installation
pip install telnyx
Setup
import os
from telnyx import Telnyx
client = Telnyx(
api_key=os.environ.get("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
GET /country_coverage
country_coverage = client.country_coverage.retrieve()
print(country_coverage.data)
Get coverage for a specific country
GET /country_coverage/countries/{country_code}
response = client.country_coverage.retrieve_country(
"US",
)
print(response.data)
Create an inventory coverage request
Creates an inventory coverage request.
GET /inventory_coverage
inventory_coverages = client.inventory_coverage.list()
print(inventory_coverages.data)
List number reservations
Gets a paginated list of phone number reservations.
GET /number_reservations
page = client.number_reservations.list()
page = page.data[0]
print(page.id)
Create a number reservation
Creates a Phone Number Reservation for multiple numbers.
POST /number_reservations
Optional: created_at (date-time), customer_reference (string), id (uuid), phone_numbers (array[object]), record_type (string), status (enum), updated_at (date-time)
number_reservation = client.number_reservations.create()
print(number_reservation.data)
Retrieve a number reservation
Gets a single phone number reservation.
GET /number_reservations/{number_reservation_id}
number_reservation = client.number_reservations.retrieve(
"number_reservation_id",
)
print(number_reservation.data)
Extend a number reservation
Extends reservation expiry time on all phone numbers.
POST /number_reservations/{number_reservation_id}/actions/extend
response = client.number_reservations.actions.extend(
"number_reservation_id",
)
print(response.data)
List number orders
Get a paginated list of number orders.
GET /number_orders
page = client.number_orders.list()
page = page.data[0]
print(page.id)
Create a number order
Creates a phone number order.
POST /number_orders
Optional: billing_group_id (string), connection_id (string), customer_reference (string), messaging_profile_id (string), phone_numbers (array[object])
number_order = client.number_orders.create()
print(number_order.data)
Retrieve a number order
Get an existing phone number order.
GET /number_orders/{number_order_id}
number_order = client.number_orders.retrieve(
"number_order_id",
)
print(number_order.data)
Update a number order
Updates a phone number order.
PATCH /number_orders/{number_order_id}
Optional: customer_reference (string), regulatory_requirements (array[object])
number_order = client.number_orders.update(
number_order_id="number_order_id",
)
print(number_order.data)
List number block orders
Get a paginated list of number block orders.
GET /number_block_orders
page = client.number_block_orders.list()
page = page.data[0]
print(page.id)
Create a number block order
Creates a phone number block order.
POST /number_block_orders â Required: starting_number, range
Optional: connection_id (string), created_at (date-time), customer_reference (string), errors (string), id (uuid), messaging_profile_id (string), phone_numbers_count (integer), record_type (string), requirements_met (boolean), status (enum), updated_at (date-time)
number_block_order = client.number_block_orders.create(
range=10,
starting_number="+19705555000",
)
print(number_block_order.data)
Retrieve a number block order
Get an existing phone number block order.
GET /number_block_orders/{number_block_order_id}
number_block_order = client.number_block_orders.retrieve(
"number_block_order_id",
)
print(number_block_order.data)
Retrieve a list of phone numbers associated to orders
Get a list of phone numbers associated to orders.
GET /number_order_phone_numbers
number_order_phone_numbers = client.number_order_phone_numbers.list()
print(number_order_phone_numbers.data)
Update requirement group for a phone number order
POST /number_order_phone_numbers/{id}/requirement_group â Required: requirement_group_id
response = client.number_order_phone_numbers.update_requirement_group(
id="182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
requirement_group_id="182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(response.data)
Retrieve a single phone number within a number order.
Get an existing phone number in number order.
GET /number_order_phone_numbers/{number_order_phone_number_id}
number_order_phone_number = client.number_order_phone_numbers.retrieve(
"number_order_phone_number_id",
)
print(number_order_phone_number.data)
Update requirements for a single phone number within a number order.
Updates requirements for a single phone number within a number order.
PATCH /number_order_phone_numbers/{number_order_phone_number_id}
Optional: regulatory_requirements (array[object])
response = client.number_order_phone_numbers.update_requirements(
number_order_phone_number_id="number_order_phone_number_id",
)
print(response.data)
List sub number orders
Get a paginated list of sub number orders.
GET /sub_number_orders
sub_number_orders = client.sub_number_orders.list()
print(sub_number_orders.data)
Update requirement group for a sub number order
POST /sub_number_orders/{id}/requirement_group â Required: requirement_group_id
response = client.sub_number_orders.update_requirement_group(
id="182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
requirement_group_id="a4b201f9-8646-4e54-a7d2-b2e403eeaf8c",
)
print(response.data)
Retrieve a sub number order
Get an existing sub number order.
GET /sub_number_orders/{sub_number_order_id}
sub_number_order = client.sub_number_orders.retrieve(
sub_number_order_id="sub_number_order_id",
)
print(sub_number_order.data)
Update a sub number order’s requirements
Updates a sub number order.
PATCH /sub_number_orders/{sub_number_order_id}
Optional: regulatory_requirements (array[object])
sub_number_order = client.sub_number_orders.update(
sub_number_order_id="sub_number_order_id",
)
print(sub_number_order.data)
Cancel a sub number order
Allows you to cancel a sub number order in ‘pending’ status.
PATCH /sub_number_orders/{sub_number_order_id}/cancel
response = client.sub_number_orders.cancel(
"sub_number_order_id",
)
print(response.data)
Create a sub number orders report
Create a CSV report for sub number orders.
POST /sub_number_orders/report
Optional: country_code (string), created_at_gt (date-time), created_at_lt (date-time), customer_reference (string), order_request_id (uuid), status (enum)
sub_number_orders_report = client.sub_number_orders_report.create()
print(sub_number_orders_report.data)
Retrieve a sub number orders report
Get the status and details of a sub number orders report.
GET /sub_number_orders/report/{report_id}
sub_number_orders_report = client.sub_number_orders_report.retrieve(
"12ade33a-21c0-473b-b055-b3c836e1c293",
)
print(sub_number_orders_report.data)
Download a sub number orders report
Download the CSV file for a completed sub number orders report.
GET /sub_number_orders/report/{report_id}/download
response = client.sub_number_orders_report.download(
"12ade33a-21c0-473b-b055-b3c836e1c293",
)
print(response)
List Advanced Orders
GET /advanced_orders
advanced_orders = client.advanced_orders.list()
print(advanced_orders.data)
Create Advanced Order
POST /advanced_orders
Optional: area_code (string), comments (string), country_code (string), customer_reference (string), features (array[object]), phone_number_type (enum), quantity (integer), requirement_group_id (uuid)
advanced_order = client.advanced_orders.create()
print(advanced_order.id)
Update Advanced Order
PATCH /advanced_orders/{advanced-order-id}/requirement_group
Optional: area_code (string), comments (string), country_code (string), customer_reference (string), features (array[object]), phone_number_type (enum), quantity (integer), requirement_group_id (uuid)
response = client.advanced_orders.update_requirement_group(
advanced_order_id="182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(response.id)
Get Advanced Order
GET /advanced_orders/{order_id}
advanced_order = client.advanced_orders.retrieve(
"182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(advanced_order.id)
List inexplicit number orders
Get a paginated list of inexplicit number orders.
GET /inexplicit_number_orders
page = client.inexplicit_number_orders.list()
page = page.data[0]
print(page.id)
Create an inexplicit number order
Create an inexplicit number order to programmatically purchase phone numbers without specifying exact numbers.
POST /inexplicit_number_orders â Required: ordering_groups
Optional: billing_group_id (string), connection_id (string), customer_reference (string), messaging_profile_id (string)
inexplicit_number_order = client.inexplicit_number_orders.create(
ordering_groups=[{
"count_requested": "count_requested",
"country_iso": "US",
"phone_number_type": "phone_number_type",
}],
)
print(inexplicit_number_order.data)
Retrieve an inexplicit number order
Get an existing inexplicit number order by ID.
GET /inexplicit_number_orders/{id}
inexplicit_number_order = client.inexplicit_number_orders.retrieve(
"182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e",
)
print(inexplicit_number_order.data)
Retrieve all comments
GET /comments
comments = client.comments.list()
print(comments.data)
Create a comment
POST /comments
Optional: body (string), comment_record_id (uuid), comment_record_type (enum), commenter (string), commenter_type (enum), created_at (date-time), id (uuid), read_at (date-time), updated_at (date-time)
comment = client.comments.create()
print(comment.data)
Retrieve a comment
GET /comments/{id}
comment = client.comments.retrieve(
"id",
)
print(comment.data)
Mark a comment as read
PATCH /comments/{id}/read
response = client.comments.mark_as_read(
"id",
)
print(response.data)
List available phone number blocks
GET /available_phone_number_blocks
available_phone_number_blocks = client.available_phone_number_blocks.list()
print(available_phone_number_blocks.data)
List available phone numbers
GET /available_phone_numbers
available_phone_numbers = client.available_phone_numbers.list()
print(available_phone_numbers.data)
Retrieve the features for a list of numbers
POST /numbers_features â Required: phone_numbers
numbers_feature = client.numbers_features.create(
phone_numbers=["string"],
)
print(numbers_feature.data)
Webhooks
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 |
Webhook payload fields
numberOrderStatusUpdate
| Field | Type | Description |
|---|---|---|
data.event_type |
string | The type of event being sent |
data.id |
uuid | Unique identifier for the event |
data.occurred_at |
date-time | ISO 8601 timestamp of when the event occurred |
data.payload.id |
uuid | |
data.payload.record_type |
string | |
data.payload.phone_numbers_count |
integer | The count of phone numbers in the number order. |
data.payload.connection_id |
string | Identifies the connection associated with this phone number. |
data.payload.messaging_profile_id |
string | Identifies the messaging profile associated with the phone number. |
data.payload.billing_group_id |
string | Identifies the messaging profile associated with the phone number. |
data.payload.phone_numbers |
array[object] | |
data.payload.sub_number_orders_ids |
array[string] | |
data.payload.status |
enum | The status of the order. |
data.payload.customer_reference |
string | A customer reference string for customer look ups. |
data.payload.created_at |
date-time | An ISO 8901 datetime string denoting when the number order was created. |
data.payload.updated_at |
date-time | An ISO 8901 datetime string for when the number order was updated. |
data.payload.requirements_met |
boolean | True if all requirements are met for every phone number, false otherwise. |
data.record_type |
string | Type of record |
meta.attempt |
integer | Webhook delivery attempt number |
meta.delivered_to |
uri | URL where the webhook was delivered |