{"id":"f6ce3e3b-3764-4109-a839-8212f1257444","shortId":"htec3Q","kind":"skill","title":"telnyx-numbers-services-javascript","tagline":">-","description":"<!-- Auto-generated from Telnyx OpenAPI specs. Do not edit. -->\n\n# Telnyx Numbers Services - JavaScript\n\n## Installation\n\n```bash\nnpm install telnyx\n```\n\n## Setup\n\n```javascript\nimport Telnyx from 'telnyx';\n\nconst client = new Telnyx({\n  apiKey: process.env['TELNYX_API_KEY'], // This is the default and can be omitted\n});\n```\n\nAll examples below assume `client` is already initialized as shown above.\n\n## Error Handling\n\nAll API calls can fail with network errors, rate limits (429), validation errors (422),\nor authentication errors (401). Always handle errors in production code:\n\n```javascript\ntry {\n  const result = await client.messages.send({ to: '+13125550001', from: '+13125550002', text: 'Hello' });\n} catch (err) {\n  if (err instanceof Telnyx.APIConnectionError) {\n    console.error('Network error — check connectivity and retry');\n  } else if (err instanceof Telnyx.RateLimitError) {\n    // 429: rate limited — wait and retry with exponential backoff\n    const retryAfter = err.headers?.['retry-after'] || 1;\n    await new Promise(r => setTimeout(r, retryAfter * 1000));\n  } else if (err instanceof Telnyx.APIError) {\n    console.error(`API error ${err.status}: ${err.message}`);\n    if (err.status === 422) {\n      console.error('Validation error — check required fields and formats');\n    }\n  }\n}\n```\n\nCommon error codes: `401` invalid API key, `403` insufficient permissions,\n`404` resource not found, `422` validation error (check field formats),\n`429` rate limited (retry with exponential backoff).\n\n## Important Notes\n\n- **Pagination:** List methods return an auto-paginating iterator. Use `for await (const item of result) { ... }` to iterate through all pages automatically.\n\n## List your voice channels for non-US zones\n\nReturns the non-US voice channels for your account. voice channels allow you to use Channel Billing for calls to your Telnyx phone numbers. Please check the Telnyx Support Articles section for full information and examples of how to utilize Channel Billing.\n\n`GET /channel_zones`\n\n```javascript\n// Automatically fetches more pages as needed.\nfor await (const channelZoneListResponse of client.channelZones.list()) {\n  console.log(channelZoneListResponse.id);\n}\n```\n\nReturns: `channels` (int64), `countries` (array[string]), `created_at` (string), `id` (string), `name` (string), `record_type` (enum: channel_zone), `updated_at` (string)\n\n## Update voice channels for non-US Zones\n\nUpdate the number of Voice Channels for the Non-US Zones. This allows your account to handle multiple simultaneous inbound calls to Non-US numbers. Use this endpoint to increase or decrease your capacity based on expected call volume.\n\n`PUT /channel_zones/{channel_zone_id}` — Required: `channels`\n\n```javascript\nconst channelZone = await client.channelZones.update('channel_zone_id', { channels: 0 });\n\nconsole.log(channelZone.id);\n```\n\nReturns: `channels` (int64), `countries` (array[string]), `created_at` (string), `id` (string), `name` (string), `record_type` (enum: channel_zone), `updated_at` (string)\n\n## List dynamic emergency addresses\n\nReturns the dynamic emergency addresses according to filters\n\n`GET /dynamic_emergency_addresses`\n\n```javascript\n// Automatically fetches more pages as needed.\nfor await (const dynamicEmergencyAddress of client.dynamicEmergencyAddresses.list()) {\n  console.log(dynamicEmergencyAddress.id);\n}\n```\n\nReturns: `administrative_area` (string), `country_code` (enum: US, CA, PR), `created_at` (string), `extended_address` (string), `house_number` (string), `house_suffix` (string), `id` (string), `locality` (string), `postal_code` (string), `record_type` (string), `sip_geolocation_id` (string), `status` (enum: pending, activated, rejected), `street_name` (string), `street_post_directional` (string), `street_pre_directional` (string), `street_suffix` (string), `updated_at` (string)\n\n## Create a dynamic emergency address.\n\nCreates a dynamic emergency address.\n\n`POST /dynamic_emergency_addresses` — Required: `house_number`, `street_name`, `locality`, `administrative_area`, `postal_code`, `country_code`\n\nOptional: `created_at` (string), `extended_address` (string), `house_suffix` (string), `id` (string), `record_type` (string), `sip_geolocation_id` (string), `status` (enum: pending, activated, rejected), `street_post_directional` (string), `street_pre_directional` (string), `street_suffix` (string), `updated_at` (string)\n\n```javascript\nconst dynamicEmergencyAddress = await client.dynamicEmergencyAddresses.create({\n  administrative_area: 'TX',\n  country_code: 'US',\n  house_number: '600',\n  locality: 'Austin',\n  postal_code: '78701',\n  street_name: 'Congress',\n});\n\nconsole.log(dynamicEmergencyAddress.data);\n```\n\nReturns: `administrative_area` (string), `country_code` (enum: US, CA, PR), `created_at` (string), `extended_address` (string), `house_number` (string), `house_suffix` (string), `id` (string), `locality` (string), `postal_code` (string), `record_type` (string), `sip_geolocation_id` (string), `status` (enum: pending, activated, rejected), `street_name` (string), `street_post_directional` (string), `street_pre_directional` (string), `street_suffix` (string), `updated_at` (string)\n\n## Get a dynamic emergency address\n\nReturns the dynamic emergency address based on the ID provided\n\n`GET /dynamic_emergency_addresses/{id}`\n\n```javascript\nconst dynamicEmergencyAddress = await client.dynamicEmergencyAddresses.retrieve(\n  '182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',\n);\n\nconsole.log(dynamicEmergencyAddress.data);\n```\n\nReturns: `administrative_area` (string), `country_code` (enum: US, CA, PR), `created_at` (string), `extended_address` (string), `house_number` (string), `house_suffix` (string), `id` (string), `locality` (string), `postal_code` (string), `record_type` (string), `sip_geolocation_id` (string), `status` (enum: pending, activated, rejected), `street_name` (string), `street_post_directional` (string), `street_pre_directional` (string), `street_suffix` (string), `updated_at` (string)\n\n## Delete a dynamic emergency address\n\nDeletes the dynamic emergency address based on the ID provided\n\n`DELETE /dynamic_emergency_addresses/{id}`\n\n```javascript\nconst dynamicEmergencyAddress = await client.dynamicEmergencyAddresses.delete(\n  '182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',\n);\n\nconsole.log(dynamicEmergencyAddress.data);\n```\n\nReturns: `administrative_area` (string), `country_code` (enum: US, CA, PR), `created_at` (string), `extended_address` (string), `house_number` (string), `house_suffix` (string), `id` (string), `locality` (string), `postal_code` (string), `record_type` (string), `sip_geolocation_id` (string), `status` (enum: pending, activated, rejected), `street_name` (string), `street_post_directional` (string), `street_pre_directional` (string), `street_suffix` (string), `updated_at` (string)\n\n## List dynamic emergency endpoints\n\nReturns the dynamic emergency endpoints according to filters\n\n`GET /dynamic_emergency_endpoints`\n\n```javascript\n// Automatically fetches more pages as needed.\nfor await (const dynamicEmergencyEndpoint of client.dynamicEmergencyEndpoints.list()) {\n  console.log(dynamicEmergencyEndpoint.dynamic_emergency_address_id);\n}\n```\n\nReturns: `callback_number` (string), `caller_name` (string), `created_at` (string), `dynamic_emergency_address_id` (string), `id` (string), `record_type` (string), `sip_from_id` (string), `status` (enum: pending, activated, rejected), `updated_at` (string)\n\n## Create a dynamic emergency endpoint.\n\nCreates a dynamic emergency endpoints.\n\n`POST /dynamic_emergency_endpoints` — Required: `dynamic_emergency_address_id`, `callback_number`, `caller_name`\n\nOptional: `created_at` (string), `id` (string), `record_type` (string), `sip_from_id` (string), `status` (enum: pending, activated, rejected), `updated_at` (string)\n\n```javascript\nconst dynamicEmergencyEndpoint = await client.dynamicEmergencyEndpoints.create({\n  callback_number: '+13125550000',\n  caller_name: 'Jane Doe Desk Phone',\n  dynamic_emergency_address_id: '0ccc7b54-4df3-4bca-a65a-3da1ecc777f0',\n});\n\nconsole.log(dynamicEmergencyEndpoint.data);\n```\n\nReturns: `callback_number` (string), `caller_name` (string), `created_at` (string), `dynamic_emergency_address_id` (string), `id` (string), `record_type` (string), `sip_from_id` (string), `status` (enum: pending, activated, rejected), `updated_at` (string)\n\n## Get a dynamic emergency endpoint\n\nReturns the dynamic emergency endpoint based on the ID provided\n\n`GET /dynamic_emergency_endpoints/{id}`\n\n```javascript\nconst dynamicEmergencyEndpoint = await client.dynamicEmergencyEndpoints.retrieve(\n  '182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',\n);\n\nconsole.log(dynamicEmergencyEndpoint.data);\n```\n\nReturns: `callback_number` (string), `caller_name` (string), `created_at` (string), `dynamic_emergency_address_id` (string), `id` (string), `record_type` (string), `sip_from_id` (string), `status` (enum: pending, activated, rejected), `updated_at` (string)\n\n## Delete a dynamic emergency endpoint\n\nDeletes the dynamic emergency endpoint based on the ID provided\n\n`DELETE /dynamic_emergency_endpoints/{id}`\n\n```javascript\nconst dynamicEmergencyEndpoint = await client.dynamicEmergencyEndpoints.delete(\n  '182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e',\n);\n\nconsole.log(dynamicEmergencyEndpoint.data);\n```\n\nReturns: `callback_number` (string), `caller_name` (string), `created_at` (string), `dynamic_emergency_address_id` (string), `id` (string), `record_type` (string), `sip_from_id` (string), `status` (enum: pending, activated, rejected), `updated_at` (string)\n\n## List your voice channels for US Zone\n\nReturns the US Zone voice channels for your account. voice channels allows you to use Channel Billing for calls to your Telnyx phone numbers. Please check the Telnyx Support Articles section for full information and examples of how to utilize Channel Billing.\n\n`GET /inbound_channels`\n\n```javascript\nconst inboundChannels = await client.inboundChannels.list();\n\nconsole.log(inboundChannels.data);\n```\n\nReturns: `channels` (integer), `record_type` (string)\n\n## Update voice channels for US Zone\n\nUpdate the number of Voice Channels for the US Zone. This allows your account to handle multiple simultaneous inbound calls to US numbers. Use this endpoint to increase or decrease your capacity based on expected call volume.\n\n`PATCH /inbound_channels` — Required: `channels`\n\n```javascript\nconst inboundChannel = await client.inboundChannels.update({ channels: 7 });\n\nconsole.log(inboundChannel.data);\n```\n\nReturns: `channels` (integer), `record_type` (string)\n\n## List All Numbers using Channel Billing\n\nRetrieve a list of all phone numbers using Channel Billing, grouped by Zone.\n\n`GET /list`\n\n```javascript\nconst response = await client.list.retrieveAll();\n\nconsole.log(response.data);\n```\n\nReturns: `number_of_channels` (integer), `numbers` (array[object]), `zone_id` (string), `zone_name` (string)\n\n## List Numbers using Channel Billing for a specific Zone\n\nRetrieve a list of phone numbers using Channel Billing for a specific Zone.\n\n`GET /list/{channel_zone_id}`\n\n```javascript\nconst response = await client.list.retrieveByZone('channel_zone_id');\n\nconsole.log(response.data);\n```\n\nReturns: `number_of_channels` (integer), `numbers` (array[object]), `zone_id` (string), `zone_name` (string)\n\n## Get voicemail\n\nReturns the voicemail settings for a phone number\n\n`GET /phone_numbers/{phone_number_id}/voicemail`\n\n```javascript\nconst voicemail = await client.phoneNumbers.voicemail.retrieve('123455678900');\n\nconsole.log(voicemail.data);\n```\n\nReturns: `enabled` (boolean), `pin` (string)\n\n## Create voicemail\n\nCreate voicemail settings for a phone number\n\n`POST /phone_numbers/{phone_number_id}/voicemail`\n\nOptional: `enabled` (boolean), `pin` (string)\n\n```javascript\nconst voicemail = await client.phoneNumbers.voicemail.create('123455678900');\n\nconsole.log(voicemail.data);\n```\n\nReturns: `enabled` (boolean), `pin` (string)\n\n## Update voicemail\n\nUpdate voicemail settings for a phone number\n\n`PATCH /phone_numbers/{phone_number_id}/voicemail`\n\nOptional: `enabled` (boolean), `pin` (string)\n\n```javascript\nconst voicemail = await client.phoneNumbers.voicemail.update('123455678900');\n\nconsole.log(voicemail.data);\n```\n\nReturns: `enabled` (boolean), `pin` (string)","tags":["telnyx","numbers","services","javascript","team-telnyx","agent-skills","ai-coding-agent","claude-code","cpaas","cursor","iot","llm"],"capabilities":["skill","source-team-telnyx","skill-telnyx-numbers-services-javascript","topic-agent-skills","topic-ai-coding-agent","topic-claude-code","topic-cpaas","topic-cursor","topic-iot","topic-llm","topic-sdk","topic-sip","topic-sms","topic-speech-to-text","topic-telephony"],"categories":["ai"],"synonyms":[],"warnings":[],"endpointUrl":"https://skills.sh/team-telnyx/ai/telnyx-numbers-services-javascript","protocol":"skill","transport":"skills-sh","auth":{"type":"none","details":{"cli":"npx skills add team-telnyx/ai","source_repo":"https://github.com/team-telnyx/ai","install_from":"skills.sh"}},"qualityScore":"0.533","qualityRationale":"deterministic score 0.53 from registry signals: · indexed on github topic:agent-skills · 167 github stars · SKILL.md body (12,232 chars)","verified":false,"liveness":"unknown","lastLivenessCheck":null,"agentReviews":{"count":0,"score_avg":null,"cost_usd_avg":null,"success_rate":null,"latency_p50_ms":null,"narrative_summary":null,"summary_updated_at":null},"enrichmentModel":"deterministic:skill-github:v1","enrichmentVersion":1,"enrichedAt":"2026-04-22T06:54:44.117Z","embedding":null,"createdAt":"2026-04-18T22:07:19.965Z","updatedAt":"2026-04-22T06:54:44.117Z","lastSeenAt":"2026-04-22T06:54:44.117Z","tsv":"'+13125550000':902 '+13125550001':82 '+13125550002':84 '/channel_zones':254,341 '/dynamic_emergency_addresses':393,478,627,716 '/dynamic_emergency_endpoints':802,864,969,1032 '/inbound_channels':1129,1187 '/list':1225,1270 '/phone_numbers':1309,1337,1370 '/voicemail':1313,1341,1374 '0':356 '0ccc7b54':914 '0ccc7b54-4df3-4bca-a65a-3da1ecc777f0':913 '1':120 '1000':128 '123455678900':1319,1352,1385 '182bd5e5':635,724,977,1040 '182bd5e5-6e1a-4fe4-a799-aa6d9a6ab26e':634,723,976,1039 '3da1ecc777f0':918 '401':68,153 '403':157 '404':160 '422':64,141,164 '429':61,105,170 '4bca':916 '4df3':915 '4fe4':637,726,979,1042 '600':542 '6e1a':636,725,978,1041 '7':1196 '78701':547 'a65a':917 'a799':638,727,980,1043 'aa6d9a6ab26e':639,728,981,1044 'accord':389,798 'account':219,314,1094,1162 'activ':448,513,592,681,770,848,890,948,1011,1074 'address':383,388,423,471,476,496,567,615,620,656,704,709,745,819,833,868,911,933,996,1059 'administr':410,485,534,554,643,732 'allow':222,312,1097,1160 'alreadi':44 'alway':69 'api':28,52,135,155 'apikey':25 'area':411,486,535,555,644,733 'array':274,363,1239,1290 'articl':240,1115 'assum':41 'austin':544 'authent':66 'auto':185 'auto-pagin':184 'automat':200,256,395,804 'await':79,121,190,263,350,402,532,632,721,811,898,974,1037,1133,1193,1229,1277,1317,1350,1383 'backoff':113,176 'base':335,621,710,963,1026,1181 'bash':11 'bill':227,252,1102,1127,1210,1220,1251,1264 'boolean':1324,1344,1357,1377,1390 'ca':417,561,650,739 'call':53,229,320,338,1104,1168,1184 'callback':822,870,900,922,985,1048 'caller':825,872,903,925,988,1051 'capac':334,1180 'catch':87 'channel':204,216,221,226,251,271,286,293,304,342,346,352,355,360,375,1082,1091,1096,1101,1126,1138,1145,1154,1189,1195,1200,1209,1219,1236,1250,1263,1271,1279,1287 'channelzon':349 'channelzone.id':358 'channelzonelistrespons':265 'channelzonelistresponse.id':269 'check':96,145,167,236,1111 'client':22,42 'client.channelzones.list':267 'client.channelzones.update':351 'client.dynamicemergencyaddresses.create':533 'client.dynamicemergencyaddresses.delete':722 'client.dynamicemergencyaddresses.list':406 'client.dynamicemergencyaddresses.retrieve':633 'client.dynamicemergencyendpoints.create':899 'client.dynamicemergencyendpoints.delete':1038 'client.dynamicemergencyendpoints.list':815 'client.dynamicemergencyendpoints.retrieve':975 'client.inboundchannels.list':1134 'client.inboundchannels.update':1194 'client.list.retrieveall':1230 'client.list.retrievebyzone':1278 'client.messages.send':80 'client.phonenumbers.voicemail.create':1351 'client.phonenumbers.voicemail.retrieve':1318 'client.phonenumbers.voicemail.update':1384 'code':74,152,414,436,488,490,538,546,558,580,647,669,736,758 'common':150 'congress':550 'connect':97 'console.error':93,134,142 'console.log':268,357,407,551,640,729,816,919,982,1045,1135,1197,1231,1282,1320,1353,1386 'const':21,77,114,191,264,348,403,530,630,719,812,896,972,1035,1131,1191,1227,1275,1315,1348,1381 'countri':273,362,413,489,537,557,646,735 'creat':276,365,419,467,472,492,563,652,741,828,853,858,875,928,991,1054,1327,1329 'decreas':332,1178 'default':33 'delet':700,705,715,1016,1021,1031 'desk':907 'direct':455,459,517,521,599,603,688,692,777,781 'doe':906 'dynam':381,386,469,474,613,618,702,707,790,795,831,855,860,866,909,931,955,960,994,1018,1023,1057 'dynamicemergencyaddress':404,531,631,720 'dynamicemergencyaddress.data':552,641,730 'dynamicemergencyaddress.id':408 'dynamicemergencyendpoint':813,897,973,1036 'dynamicemergencyendpoint.data':920,983,1046 'dynamicemergencyendpoint.dynamic':817 'els':100,129 'emerg':382,387,470,475,614,619,703,708,791,796,818,832,856,861,867,910,932,956,961,995,1019,1024,1058 'enabl':1323,1343,1356,1376,1389 'endpoint':328,792,797,857,862,957,962,1020,1025,1174 'enum':285,374,415,446,511,559,590,648,679,737,768,846,888,946,1009,1072 'err':88,90,102,131 'err.headers':116 'err.message':138 'err.status':137,140 'error':49,58,63,67,71,95,136,144,151,166 'exampl':39,246,1121 'expect':337,1183 'exponenti':112,175 'extend':422,495,566,655,744 'fail':55 'fetch':257,396,805 'field':147,168 'filter':391,800 'format':149,169 'found':163 'full':243,1118 'geoloc':442,507,586,675,764 'get':253,392,611,626,801,953,968,1128,1224,1269,1298,1308 'group':1221 'handl':50,70,316,1164 'hello':86 'hous':425,428,480,498,540,569,572,658,661,747,750 'id':279,344,354,368,431,443,501,508,575,587,624,628,664,676,713,717,753,765,820,834,836,843,869,878,885,912,934,936,943,966,970,997,999,1006,1029,1033,1060,1062,1069,1242,1273,1281,1293,1312,1340,1373 'import':17,177 'inbound':319,1167 'inboundchannel':1132,1192 'inboundchannel.data':1198 'inboundchannels.data':1136 'increas':330,1176 'inform':244,1119 'initi':45 'instal':10,13 'instanceof':91,103,132 'insuffici':158 'int64':272,361 'integ':1139,1201,1237,1288 'invalid':154 'item':192 'iter':187,196 'jane':905 'javascript':5,9,16,75,255,347,394,529,629,718,803,895,971,1034,1130,1190,1226,1274,1314,1347,1380 'key':29,156 'limit':60,107,172 'list':180,201,380,789,1079,1205,1213,1247,1258 'local':433,484,543,577,666,755 'method':181 'multipl':317,1165 'name':281,370,451,483,549,595,684,773,826,873,904,926,989,1052,1245,1296 'need':261,400,809 'network':57,94 'new':23,122 'non':207,213,296,308,323 'non-us':206,212,295,307,322 'note':178 'npm':12 'number':3,7,234,301,325,426,481,541,570,659,748,823,871,901,923,986,1049,1109,1151,1171,1207,1217,1234,1238,1248,1261,1285,1289,1307,1311,1335,1339,1368,1372 'object':1240,1291 'omit':37 'option':491,874,1342,1375 'page':199,259,398,807 'pagin':179,186 'patch':1186,1369 'pend':447,512,591,680,769,847,889,947,1010,1073 'permiss':159 'phone':233,908,1108,1216,1260,1306,1310,1334,1338,1367,1371 'pin':1325,1345,1358,1378,1391 'pleas':235,1110 'post':454,477,516,598,687,776,863,1336 'postal':435,487,545,579,668,757 'pr':418,562,651,740 'pre':458,520,602,691,780 'process.env':26 'product':73 'promis':123 'provid':625,714,967,1030 'put':340 'r':124,126 'rate':59,106,171 'record':283,372,438,503,582,671,760,838,880,938,1001,1064,1140,1202 'reject':449,514,593,682,771,849,891,949,1012,1075 'requir':146,345,479,865,1188 'resourc':161 'respons':1228,1276 'response.data':1232,1283 'result':78,194 'retri':99,110,118,173 'retriev':1211,1256 'retry-aft':117 'retryaft':115,127 'return':182,210,270,359,384,409,553,616,642,731,793,821,921,958,984,1047,1086,1137,1199,1233,1284,1300,1322,1355,1388 'section':241,1116 'servic':4,8 'set':1303,1331,1364 'settimeout':125 'setup':15 'shown':47 'simultan':318,1166 'sip':441,506,585,674,763,841,883,941,1004,1067 'skill' 'skill-telnyx-numbers-services-javascript' 'source-team-telnyx' 'specif':1254,1267 'status':445,510,589,678,767,845,887,945,1008,1071 'street':450,453,457,461,482,515,519,523,548,594,597,601,605,683,686,690,694,772,775,779,783 'string':275,278,280,282,290,364,367,369,371,379,412,421,424,427,430,432,434,437,440,444,452,456,460,463,466,494,497,500,502,505,509,518,522,525,528,556,565,568,571,574,576,578,581,584,588,596,600,604,607,610,645,654,657,660,663,665,667,670,673,677,685,689,693,696,699,734,743,746,749,752,754,756,759,762,766,774,778,782,785,788,824,827,830,835,837,840,844,852,877,879,882,886,894,924,927,930,935,937,940,944,952,987,990,993,998,1000,1003,1007,1015,1050,1053,1056,1061,1063,1066,1070,1078,1142,1204,1243,1246,1294,1297,1326,1346,1359,1379,1392 'suffix':429,462,499,524,573,606,662,695,751,784 'support':239,1114 'telnyx':2,6,14,18,20,24,27,232,238,1107,1113 'telnyx-numbers-services-javascript':1 'telnyx.apiconnectionerror':92 'telnyx.apierror':133 'telnyx.ratelimiterror':104 'text':85 'topic-agent-skills' 'topic-ai-coding-agent' 'topic-claude-code' 'topic-cpaas' 'topic-cursor' 'topic-iot' 'topic-llm' 'topic-sdk' 'topic-sip' 'topic-sms' 'topic-speech-to-text' 'topic-telephony' 'tri':76 'tx':536 'type':284,373,439,504,583,672,761,839,881,939,1002,1065,1141,1203 'updat':288,291,299,377,464,526,608,697,786,850,892,950,1013,1076,1143,1149,1360,1362 'us':208,214,297,309,324,416,539,560,649,738,1084,1088,1147,1157,1170 'use':188,225,326,1100,1172,1208,1218,1249,1262 'util':250,1125 'valid':62,143,165 'voic':203,215,220,292,303,1081,1090,1095,1144,1153 'voicemail':1299,1302,1316,1328,1330,1349,1361,1363,1382 'voicemail.data':1321,1354,1387 'volum':339,1185 'wait':108 'zone':209,287,298,310,343,353,376,1085,1089,1148,1158,1223,1241,1244,1255,1268,1272,1280,1292,1295","prices":[{"id":"45e432e0-bd2a-41d3-b1fb-66129291ca58","listingId":"f6ce3e3b-3764-4109-a839-8212f1257444","amountUsd":"0","unit":"free","nativeCurrency":null,"nativeAmount":null,"chain":null,"payTo":null,"paymentMethod":"skill-free","isPrimary":true,"details":{"org":"team-telnyx","category":"ai","install_from":"skills.sh"},"createdAt":"2026-04-18T22:07:19.965Z"}],"sources":[{"listingId":"f6ce3e3b-3764-4109-a839-8212f1257444","source":"github","sourceId":"team-telnyx/ai/telnyx-numbers-services-javascript","sourceUrl":"https://github.com/team-telnyx/ai/tree/main/skills/telnyx-numbers-services-javascript","isPrimary":false,"firstSeenAt":"2026-04-18T22:07:19.965Z","lastSeenAt":"2026-04-22T06:54:44.117Z"}],"details":{"listingId":"f6ce3e3b-3764-4109-a839-8212f1257444","quickStartSnippet":null,"exampleRequest":null,"exampleResponse":null,"schema":null,"openapiUrl":null,"agentsTxtUrl":null,"citations":[],"useCases":[],"bestFor":[],"notFor":[],"kindDetails":{"org":"team-telnyx","slug":"telnyx-numbers-services-javascript","github":{"repo":"team-telnyx/ai","stars":167,"topics":["agent-skills","ai","ai-coding-agent","claude-code","cpaas","cursor","iot","llm","sdk","sip","sms","speech-to-text","telephony","telnyx","tts","twilio-migration","voice-agents","voice-ai","webrtc","windsurf"],"license":"mit","html_url":"https://github.com/team-telnyx/ai","pushed_at":"2026-04-21T22:09:49Z","description":"Official one-stop shop for AI Agents and developers building with Telnyx.","skill_md_sha":"aae3a1f8564556289cdfc45a1f139180ab05c5db","skill_md_path":"skills/telnyx-numbers-services-javascript/SKILL.md","default_branch":"main","skill_tree_url":"https://github.com/team-telnyx/ai/tree/main/skills/telnyx-numbers-services-javascript"},"layout":"multi","source":"github","category":"ai","frontmatter":{"name":"telnyx-numbers-services-javascript","description":">-"},"skills_sh_url":"https://skills.sh/team-telnyx/ai/telnyx-numbers-services-javascript"},"updatedAt":"2026-04-22T06:54:44.117Z"}}