Python / Zoom API / Get account plan information
Back to Collection Items
import sys
import chilkat
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
http = chilkat.CkHttp()
# Adds the "Authorization: Bearer <access_token>" header.
http.put_AuthToken("<access_token>")
sbResponseBody = chilkat.CkStringBuilder()
success = http.QuickGetSb("https://api.zoom.us/v2/accounts/:accountId/plans",sbResponseBody)
if (success == False):
print(http.lastErrorText())
sys.exit()
jResp = chilkat.CkJsonObject()
jResp.LoadSb(sbResponseBody)
jResp.put_EmitCompact(False)
print("Response Body:")
print(jResp.emit())
respStatusCode = http.get_LastStatus()
print("Response Status Code = " + str(respStatusCode))
if (respStatusCode >= 400):
print("Response Header:")
print(http.lastHeader())
print("Failed.")
sys.exit()
# Sample JSON response:
# (Sample code for parsing the JSON response is shown below)
# {
# "plan_base": {
# "type": "monthly",
# "hosts": 100,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# },
# "plan_zoom_rooms": {
# "type": "zroom_monthly",
# "hosts": 50,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# },
# "plan_room_connector": {
# "type": "roomconnector_monthly",
# "hosts": 10,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# },
# "plan_large_meeting": [
# {
# "type": "plan_large500_two_years",
# "hosts": 10,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# }
# ],
# "plan_webinar": [
# {
# "type": "webinar500_monthly",
# "hosts": 10,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# }
# ],
# "plan_zoom_events": [
# {
# "type": "zoomevents500_monthly",
# "hosts": 20,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# }
# ],
# "plan_recording": "cmr_monthly_commitment_40",
# "plan_recording_service_effective_date": "2021-09-07T00:00:00Z",
# "plan_recording_next_invoice_date": "2021-10-07T00:00:00Z",
# "plan_recording_status": "status",
# "plan_audio": {
# "type": "tollfree_payongo",
# "tollfree_countries": "US",
# "premium_countries": "",
# "callout_countries": "",
# "ddi_numbers": 0,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# },
# "plan_phone": {
# "plan_base": {
# "type": "phone_payongo",
# "callout_countries": "",
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# },
# "plan_calling": [
# {
# "type": "phone_calling_usca_monthly_unlimited",
# "hosts": 5,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# }
# ],
# "plan_number": [
# {
# "type": "phone_number_usca_monthly",
# "hosts": 5,
# "service_effective_date": "2021-09-07T00:00:00Z",
# "next_invoice_date": "2021-10-07T00:00:00Z",
# "status": "active"
# }
# ]
# }
# }
# Sample code for parsing the JSON response...
# Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code
v_Type = jResp.stringOf("plan_base.type")
Hosts = jResp.IntOf("plan_base.hosts")
Service_effective_date = jResp.stringOf("plan_base.service_effective_date")
Next_invoice_date = jResp.stringOf("plan_base.next_invoice_date")
Status = jResp.stringOf("plan_base.status")
plan_zoom_roomsType = jResp.stringOf("plan_zoom_rooms.type")
plan_zoom_roomsHosts = jResp.IntOf("plan_zoom_rooms.hosts")
plan_zoom_roomsService_effective_date = jResp.stringOf("plan_zoom_rooms.service_effective_date")
plan_zoom_roomsNext_invoice_date = jResp.stringOf("plan_zoom_rooms.next_invoice_date")
plan_zoom_roomsStatus = jResp.stringOf("plan_zoom_rooms.status")
plan_room_connectorType = jResp.stringOf("plan_room_connector.type")
plan_room_connectorHosts = jResp.IntOf("plan_room_connector.hosts")
plan_room_connectorService_effective_date = jResp.stringOf("plan_room_connector.service_effective_date")
plan_room_connectorNext_invoice_date = jResp.stringOf("plan_room_connector.next_invoice_date")
plan_room_connectorStatus = jResp.stringOf("plan_room_connector.status")
plan_recording = jResp.stringOf("plan_recording")
plan_recording_service_effective_date = jResp.stringOf("plan_recording_service_effective_date")
plan_recording_next_invoice_date = jResp.stringOf("plan_recording_next_invoice_date")
plan_recording_status = jResp.stringOf("plan_recording_status")
plan_audioType = jResp.stringOf("plan_audio.type")
Tollfree_countries = jResp.stringOf("plan_audio.tollfree_countries")
Premium_countries = jResp.stringOf("plan_audio.premium_countries")
Callout_countries = jResp.stringOf("plan_audio.callout_countries")
Ddi_numbers = jResp.IntOf("plan_audio.ddi_numbers")
plan_audioService_effective_date = jResp.stringOf("plan_audio.service_effective_date")
plan_audioNext_invoice_date = jResp.stringOf("plan_audio.next_invoice_date")
plan_audioStatus = jResp.stringOf("plan_audio.status")
Plan_baseType = jResp.stringOf("plan_phone.plan_base.type")
Plan_baseCallout_countries = jResp.stringOf("plan_phone.plan_base.callout_countries")
Plan_baseService_effective_date = jResp.stringOf("plan_phone.plan_base.service_effective_date")
Plan_baseNext_invoice_date = jResp.stringOf("plan_phone.plan_base.next_invoice_date")
Plan_baseStatus = jResp.stringOf("plan_phone.plan_base.status")
i = 0
count_i = jResp.SizeOfArray("plan_large_meeting")
while i < count_i :
jResp.put_I(i)
v_type = jResp.stringOf("plan_large_meeting[i].type")
hosts = jResp.IntOf("plan_large_meeting[i].hosts")
service_effective_date = jResp.stringOf("plan_large_meeting[i].service_effective_date")
next_invoice_date = jResp.stringOf("plan_large_meeting[i].next_invoice_date")
status = jResp.stringOf("plan_large_meeting[i].status")
i = i + 1
i = 0
count_i = jResp.SizeOfArray("plan_webinar")
while i < count_i :
jResp.put_I(i)
v_type = jResp.stringOf("plan_webinar[i].type")
hosts = jResp.IntOf("plan_webinar[i].hosts")
service_effective_date = jResp.stringOf("plan_webinar[i].service_effective_date")
next_invoice_date = jResp.stringOf("plan_webinar[i].next_invoice_date")
status = jResp.stringOf("plan_webinar[i].status")
i = i + 1
i = 0
count_i = jResp.SizeOfArray("plan_zoom_events")
while i < count_i :
jResp.put_I(i)
v_type = jResp.stringOf("plan_zoom_events[i].type")
hosts = jResp.IntOf("plan_zoom_events[i].hosts")
service_effective_date = jResp.stringOf("plan_zoom_events[i].service_effective_date")
next_invoice_date = jResp.stringOf("plan_zoom_events[i].next_invoice_date")
status = jResp.stringOf("plan_zoom_events[i].status")
i = i + 1
i = 0
count_i = jResp.SizeOfArray("plan_phone.plan_calling")
while i < count_i :
jResp.put_I(i)
v_type = jResp.stringOf("plan_phone.plan_calling[i].type")
hosts = jResp.IntOf("plan_phone.plan_calling[i].hosts")
service_effective_date = jResp.stringOf("plan_phone.plan_calling[i].service_effective_date")
next_invoice_date = jResp.stringOf("plan_phone.plan_calling[i].next_invoice_date")
status = jResp.stringOf("plan_phone.plan_calling[i].status")
i = i + 1
i = 0
count_i = jResp.SizeOfArray("plan_phone.plan_number")
while i < count_i :
jResp.put_I(i)
v_type = jResp.stringOf("plan_phone.plan_number[i].type")
hosts = jResp.IntOf("plan_phone.plan_number[i].hosts")
service_effective_date = jResp.stringOf("plan_phone.plan_number[i].service_effective_date")
next_invoice_date = jResp.stringOf("plan_phone.plan_number[i].next_invoice_date")
status = jResp.stringOf("plan_phone.plan_number[i].status")
i = i + 1
Curl Command
curl -X GET
-H "Authorization: Bearer <access_token>"
https://api.zoom.us/v2/accounts/:accountId/plans
Postman Collection Item JSON
{
"name": "Get account plan information",
"request": {
"method": "GET",
"header": [
],
"url": {
"raw": "{{baseUrl}}/accounts/:accountId/plans",
"host": [
"{{baseUrl}}"
],
"path": [
"accounts",
":accountId",
"plans"
],
"variable": [
{
"key": "accountId",
"value": "quis officia in reprehenderit",
"description": "(Required) The account's ID."
}
]
},
"description": "Use this API to return plan information of a subaccount that is managed by a Master account. \n\n This API can only be used by Master accounts that pay all billing charges of their associated Pro or higher subaccounts. Zoom only allows approved partners to use [Master APIs](https://marketplace.zoom.us/docs/api-reference/master-account-apis) and manage subaccounts' billing information. Email the partner programs team at [**partner-success@zoom.us**](mailto:partner-success@zoom.us) for more details. \n\n **Scopes:** `billing:master`, `billing:read:admin` <br> **[Rate Limit Label](https://marketplace.zoom.us/docs/api-reference/rate-limits#rate-limits):** `Medium`"
},
"response": [
{
"name": "**HTTP Status Code:**`200`<br>\nAccount's plans returned.\n",
"originalRequest": {
"method": "GET",
"header": [
{
"description": "Added as a part of security scheme: oauth2",
"key": "Authorization",
"value": "<token>"
}
],
"url": {
"raw": "{{baseUrl}}/accounts/:accountId/plans",
"host": [
"{{baseUrl}}"
],
"path": [
"accounts",
":accountId",
"plans"
],
"variable": [
{
"key": "accountId",
"value": "quis officia in reprehenderit",
"description": "(Required) The account's ID."
}
]
}
},
"status": "OK",
"code": 200,
"_postman_previewlanguage": "json",
"header": [
{
"key": "Content-Type",
"value": "application/json"
}
],
"cookie": [
],
"body": "{\n \"plan_base\": {\n \"type\": \"monthly\",\n \"hosts\": 100,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n },\n \"plan_zoom_rooms\": {\n \"type\": \"zroom_monthly\",\n \"hosts\": 50,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n },\n \"plan_room_connector\": {\n \"type\": \"roomconnector_monthly\",\n \"hosts\": 10,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n },\n \"plan_large_meeting\": [\n {\n \"type\": \"plan_large500_two_years\",\n \"hosts\": 10,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n }\n ],\n \"plan_webinar\": [\n {\n \"type\": \"webinar500_monthly\",\n \"hosts\": 10,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n }\n ],\n \"plan_zoom_events\": [\n {\n \"type\": \"zoomevents500_monthly\",\n \"hosts\": 20,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n }\n ],\n \"plan_recording\": \"cmr_monthly_commitment_40\",\n \"plan_recording_service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"plan_recording_next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"plan_recording_status\": \"status\",\n \"plan_audio\": {\n \"type\": \"tollfree_payongo\",\n \"tollfree_countries\": \"US\",\n \"premium_countries\": \"\",\n \"callout_countries\": \"\",\n \"ddi_numbers\": 0,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n },\n \"plan_phone\": {\n \"plan_base\": {\n \"type\": \"phone_payongo\",\n \"callout_countries\": \"\",\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n },\n \"plan_calling\": [\n {\n \"type\": \"phone_calling_usca_monthly_unlimited\",\n \"hosts\": 5,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n }\n ],\n \"plan_number\": [\n {\n \"type\": \"phone_number_usca_monthly\",\n \"hosts\": 5,\n \"service_effective_date\": \"2021-09-07T00:00:00Z\",\n \"next_invoice_date\": \"2021-10-07T00:00:00Z\",\n \"status\": \"active\"\n }\n ]\n }\n}"
},
{
"name": "**HTTP Status Code:** `400`<br>\n**Error Code:** `2100`<br> \nThis sub account is on self pay mode.",
"originalRequest": {
"method": "GET",
"header": [
{
"description": "Added as a part of security scheme: oauth2",
"key": "Authorization",
"value": "<token>"
}
],
"url": {
"raw": "{{baseUrl}}/accounts/:accountId/plans",
"host": [
"{{baseUrl}}"
],
"path": [
"accounts",
":accountId",
"plans"
],
"variable": [
{
"key": "accountId",
"value": "quis officia in reprehenderit",
"description": "(Required) The account's ID."
}
]
}
},
"status": "Bad Request",
"code": 400,
"_postman_previewlanguage": "text",
"header": [
{
"key": "Content-Type",
"value": "text/plain"
}
],
"cookie": [
],
"body": ""
},
{
"name": "**HTTP Status Code:**`404`<br>\nAccount does not exist: {subAccountId}.",
"originalRequest": {
"method": "GET",
"header": [
{
"description": "Added as a part of security scheme: oauth2",
"key": "Authorization",
"value": "<token>"
}
],
"url": {
"raw": "{{baseUrl}}/accounts/:accountId/plans",
"host": [
"{{baseUrl}}"
],
"path": [
"accounts",
":accountId",
"plans"
],
"variable": [
{
"key": "accountId",
"value": "quis officia in reprehenderit",
"description": "(Required) The account's ID."
}
]
}
},
"status": "Not Found",
"code": 404,
"_postman_previewlanguage": "text",
"header": [
{
"key": "Content-Type",
"value": "text/plain"
}
],
"cookie": [
],
"body": ""
}
]
}