Source code for wxc_sdk.telephony.paging

"""
Paging group API

"""
import json
from collections.abc import Generator
from typing import Optional, List, Dict

from pydantic import Field

from ..api_child import ApiChild
from ..base import ApiModel, to_camel
from ..common import UserType, DirectLineCallerIdName

__all__ = ['PagingApi', 'Paging', 'PagingAgent']

from ..person_settings.available_numbers import AvailableNumber


[docs] class PagingAgent(ApiModel): #: Agents ID agent_id: Optional[str] = Field(alias='id', default=None) #: Agents first name. Minimum length is 1. Maximum length is 30. first_name: Optional[str] = None #: Agents last name. Minimum length is 1. Maximum length is 30. last_name: Optional[str] = None #: Type of the person or workspace. agent_type: Optional[UserType] = Field(alias='type', default=None) #: Agents phone number. Minimum length is 1. Maximum length is 23. Either phoneNumber or extension is mandatory. phone_number: Optional[str] = None #: Agents extension. Minimum length is 2. Maximum length is 10. Either phoneNumber or extension is mandatory. extension: Optional[str] = None #: Routing prefix of location. routingPrefix: Optional[str] = None #: Routing prefix + extension of a person or workspace. esn: Optional[str] = None @classmethod def create_update_exclude(cls) -> dict: """ What to exclude in JSON for create and update :meta private: """ return {'first_name': True, 'last_name': True, 'agent_type': True, 'phone_number': True, 'extension': True, 'esn': True, 'routing_prefix': True}
[docs] class Paging(ApiModel): #: A unique identifier for the paging group. paging_id: Optional[str] = Field(alias='id', default=None) #: Whether or not the paging group is enabled. enabled: Optional[bool] = None #: Unique name for the paging group. Minimum length is 1. Maximum length is 30. name: Optional[str] = None #: Paging group phone number. Minimum length is 1. Maximum length is 23. Either phoneNumber or extension is #: mandatory. phone_number: Optional[str] = None #: Paging group extension. Minimum length is 2. Maximum length is 10. Either phoneNumber or extension is mandatory. extension: Optional[str] = None #: Routing prefix of location. routing_prefix: Optional[str] = None #: Routing prefix + extension of a person or workspace. esn: Optional[str] = None #: is the phone numer a toll free number? toll_free_number: Optional[bool] = None #: Paging language. Minimum length is 1. Maximum length is 40. language: Optional[str] = None #: Language code. language_code: Optional[str] = None #: First name that displays when a group page is performed. Minimum length is 1. Maximum length is 64. This field #: has been deprecated. Please use `directLineCallerIdName` and `dialByName` instead. first_name: Optional[str] = None #: Last name that displays when a group page is performed. Minimum length is 1. Maximum length is 64. This field #: has been deprecated. Please use `directLineCallerIdName` and `dialByName` instead. last_name: Optional[str] = None #: Determines what is shown on target users caller ID when a group page is performed. If true shows page originator #: ID. originator_caller_id_enabled: Optional[bool] = None #: An array of people and/or workspaces, who may originate pages to this paging group. originators: Optional[list[PagingAgent]] = None #: An array of people, workspaces and virtual lines IDs will add to a paging group as paging call targets. targets: Optional[list[PagingAgent]] = None #: Name of location for paging group. Only present in list() response. #: When creating a paging group then this is a list of agent IDs. The details() call returns detailed agent #: information location_name: Optional[str] = None #: ID of location for paging group. Only present in list() response. location_id: Optional[str] = None #: Settings for the direct line caller ID name to be shown for this Group Paging. direct_line_caller_id_name: Optional[DirectLineCallerIdName] = None #: The name to be used for dial by name functions. dial_by_name: Optional[str] = None
[docs] def create_or_update(self) -> Dict: """ Get JSON for create or update call :return: JSON :rtype: dict """ data = self.model_dump(mode='json', by_alias=True, exclude_unset=True, exclude={'paging_id': True, 'toll_free_number': True, 'language': True, 'originators': {'__all__': PagingAgent.create_update_exclude()}, 'targets': {'__all__': PagingAgent.create_update_exclude()}, 'location_name': True, 'location_id': True, 'esn': True, 'routing_prefix': True}) # originators and targets are only ID lists def to_id(key: str): if data.get(key): data[key] = [e['id'] for e in data[key]] to_id('originators') to_id('targets') return json.dumps(data)
[docs] @staticmethod def create(*, name: str, phone_number: str = None, extension: str = None) -> 'Paging': """ Get minimal paging group settings that can be used to create a paging group by calling :meth:`PagingApi.create` with these settings. :param name: Unique name for the paging group. Minimum length is 1. Maximum length is 30. :type name: str :param phone_number: Paging group phone number. Minimum length is 1. Maximum length is 23. Either phone_number or extension is mandatory. :type phone_number: str :param extension: Paging group extension. Minimum length is 2. Maximum length is 10. Either phone_number or extension is mandatory. :type extension: str :return: settings for :meth:`PagingApi.create` call :rtype: :class:`Paging` """ if not any((phone_number, extension)): raise ValueError('Either phone_number or extension is mandatory.') return Paging(name=name, phone_number=phone_number, extension=extension)
[docs] class PagingApi(ApiChild, base='telephony/config'): def _endpoint(self, *, location_id: str = None, paging_id: str = None, path: str = None) -> str: """ endpoint for paging group operation :meta private: :param location_id: :type location_id: str :param paging_id: :type paging_id: str """ if location_id is None: return super().ep('paging') paging_id = paging_id and f'/{paging_id}' or '' path = path and f'/{path}' or '' return super().ep(f'locations/{location_id}/paging{paging_id}{path}')
[docs] def list(self, location_id: str = None, name: str = None, phone_number: str = None, org_id: str = None, **params) -> Generator[Paging, None, None]: """ Read the List of Paging Groups List all Paging Groups for the organization. Group Paging allows a person to place a one-way call or group page to up to 75 people and/or workspaces by dialing a number or extension assigned to a specific paging group. The Group Paging service makes a simultaneous call to all the assigned targets. Retrieving this list requires a full or read-only administrator auth token with a scope of spark-admin:telephony_config_read. :param location_id: Return only paging groups with matching location ID. Default is all locations :type location_id: str :param name: Return only paging groups with the matching name. :type name: str :param phone_number: Return only paging groups with matching primary phone number or extension. :type phone_number: str :param org_id: List paging groups for this organization. :type org_id: str :return: generator of class:`Paging` objects """ params.update((to_camel(k), v) for i, (k, v) in enumerate(locals().items()) if i and v is not None and k != 'params') url = self._endpoint() # noinspection PyTypeChecker return self.session.follow_pagination(url=url, model=Paging, params=params, item_key='locationPaging') pass
[docs] def create(self, location_id: str, settings: Paging, org_id: str = None) -> str: """ Create a new Paging Group Create a new Paging Group for the given location. Group Paging allows a person to place a one-way call or group page to up to 75 people and/or workspaces by dialing a number or extension assigned to a specific paging group. The Group Paging service makes a simultaneous call to all the assigned targets. Creating a paging group requires a full administrator auth token with a scope of spark-admin:telephony_config_write. :param location_id: Create the paging group for this location. :type location_id: str :param settings: new paging group :type settings: Paging :param org_id: Create the paging group for this organization. :type org_id: str :return: ID of the newly created paging group. :rtype: str """ params = org_id and {'orgId': org_id} or None if settings.originators and settings.originator_caller_id_enabled is None: raise TypeError('originator_caller_id_enabled required if originators are provided') url = self._endpoint(location_id=location_id) data = settings.create_or_update() data = self.post(url, json=data, params=params) return data['id']
[docs] def delete_paging(self, location_id: str, paging_id: str, org_id: str = None): """ Delete a Paging Group Delete the designated Paging Group. Group Paging allows a person to place a one-way call or group page to up to 75 people and/or workspaces by dialing a number or extension assigned to a specific paging group. The Group Paging service makes a simultaneous call to all the assigned targets. Deleting a paging group requires a full administrator auth token with a scope of spark-admin:telephony_config_write. :param location_id: Location from which to delete a paging group. :type location_id: str :param paging_id: Delete the paging group with the matching ID. :param org_id: Delete the paging group from this organization. """ params = org_id and {'orgId': org_id} or None url = self._endpoint(location_id=location_id, paging_id=paging_id) self.delete(url, params=params)
[docs] def details(self, location_id: str, paging_id: str, org_id: str = None) -> Paging: """ Get Details for a Paging Group Retrieve Paging Group details. Group Paging allows a person to place a one-way call or group page to up to 75 people and/or workspaces by dialing a number or extension assigned to a specific paging group. The Group Paging service makes a simultaneous call to all the assigned targets. Retrieving paging group details requires a full or read-only administrator auth token with a scope of spark-admin:telephony_config_read. :param location_id: Retrieve settings for a paging group in this location. :param paging_id: Retrieve settings for the paging group with this identifier. :param org_id: Retrieve paging group settings from this organization. :return: :class:`Paging` object """ params = org_id and {'orgId': org_id} or None url = self._endpoint(location_id=location_id, paging_id=paging_id) return Paging.model_validate(self.get(url, params=params))
[docs] def update(self, location_id: str, update: Paging, paging_id: str, org_id: str = None): """ Update a Paging Group Update the designated Paging Group. Group Paging allows a person to place a one-way call or group page to up to 75 people and/or workspaces by dialing a number or extension assigned to a specific paging group. The Group Paging service makes a simultaneous call to all the assigned targets. Updating a paging group requires a full administrator auth token with a scope of spark-admin:telephony_config_write. :param location_id: Update settings for a paging group in this location. :type location_id: str :param update: update parameters :type update: Paging :param paging_id: Update settings for the paging group with this identifier. :type paging_id: str :param org_id: Update paging group settings from this organization. :type org_id: str """ params = org_id and {'orgId': org_id} or None url = self._endpoint(location_id=location_id, paging_id=paging_id) data = update.create_or_update() self.put(url, json=data, params=params)
[docs] def primary_available_phone_numbers(self, location_id: str, phone_number: List[str] = None, org_id: str = None, **params) -> Generator[AvailableNumber, None, None]: """ Get Paging Group Primary Available Phone Numbers List service and standard numbers that are available to be assigned as the paging group's primary phone number. These numbers are associated with the location specified in the request URL, can be active or inactive, and are unassigned. The available numbers APIs help identify candidate numbers and their owning entities to simplify the assignment or association of these numbers to members or features. Retrieving this list requires a full, read-only or location administrator auth token with a scope of `spark-admin:telephony_config_read`. :param location_id: Return the list of phone numbers for this location within the given organization. The maximum length is 36. :type location_id: str :param phone_number: Filter phone numbers based on the comma-separated list provided in the `phoneNumber` array. :type phone_number: list[str] :param org_id: List numbers for this organization. :type org_id: str :return: Generator yielding :class:`AvailableNumber` instances """ if org_id is not None: params['orgId'] = org_id if phone_number is not None: params['phoneNumber'] = ','.join(phone_number) url = self._endpoint(location_id=location_id, path='availableNumbers') return self.session.follow_pagination(url=url, model=AvailableNumber, item_key='phoneNumbers', params=params)