Totogi Charging as a Service API
Welcome to the Totogi Charging as a Service API. This GraphQL API is useful for querying balances and EDRs, provisioning subscribers and devices, subscribing to plans and managing configuration.
API Endpoints
# US Tenants:
https://gql.produseast1.api.totogi.com/graphql
# Singapore Tenants:
https://gql.prodapsoutheast1.api.totogi.com/graphql
Version
generated at 2025-10-30T16:59:16Z
Queries
getAccount
Description
Returns an account for a provider by an account ID.
Response
Returns an AccountResult
Example
Query
query getAccount(
$providerId: ID!,
$accountId: ID!,
$balanceTypeIds: [ID!]
) {
getAccount(
providerId: $providerId,
accountId: $accountId,
balanceTypeIds: $balanceTypeIds
) {
... on Account {
...AccountFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": 4,
"accountId": 4,
"balanceTypeIds": ["4"]
}
Response
{"data": {"getAccount": Account}}
getAccountBalanceTypeCounters
Description
Retrieve Balance Type Counters configured for an account.
Response
Returns an AccountBalanceTypeCountersResult
Arguments
| Name | Description |
|---|---|
input - GetAccountBalanceTypeCountersInput!
|
Example
Query
query getAccountBalanceTypeCounters($input: GetAccountBalanceTypeCountersInput!) {
getAccountBalanceTypeCounters(input: $input) {
... on AccountNotFound {
...AccountNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on AccountBalanceTypeCountersPayload {
...AccountBalanceTypeCountersPayloadFragment
}
... on AccountBalanceTypeCounterNotFound {
...AccountBalanceTypeCounterNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": GetAccountBalanceTypeCountersInput}
Response
{
"data": {
"getAccountBalanceTypeCounters": AccountNotFound
}
}
getBalanceType
Description
Gets the balance type information of a specific balance type ID.
Response
Returns a GetBalanceTypeResult
Arguments
| Name | Description |
|---|---|
getBalanceTypeInput - GetBalanceTypeInput!
|
Includes the provider ID and balance type ID. |
Example
Query
query getBalanceType($getBalanceTypeInput: GetBalanceTypeInput!) {
getBalanceType(getBalanceTypeInput: $getBalanceTypeInput) {
... on BalanceTypePayload {
...BalanceTypePayloadFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"getBalanceTypeInput": GetBalanceTypeInput}
Response
{"data": {"getBalanceType": BalanceTypePayload}}
getBalanceTypeCounters
Description
Retrieve Balance Type Counter notifications based on the provided input parameters. At least one value must be supplied.
Response
Returns a GetBalanceTypeCountersResult
Arguments
| Name | Description |
|---|---|
input - GetBalanceTypeCountersInput!
|
Example
Query
query getBalanceTypeCounters($input: GetBalanceTypeCountersInput!) {
getBalanceTypeCounters(input: $input) {
... on BalanceTypeCountersPayload {
...BalanceTypeCountersPayloadFragment
}
... on BalanceTypeCounterNotFound {
...BalanceTypeCounterNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": GetBalanceTypeCountersInput}
Response
{
"data": {
"getBalanceTypeCounters": BalanceTypeCountersPayload
}
}
getBalanceTypes
Description
Gets the balance type information of a list or all balance type IDs. If none is provided, all are returned. If some are provided, the ones that are found are returned.
Response
Returns a GetBalanceTypesResult
Arguments
| Name | Description |
|---|---|
getBalanceTypesInput - GetBalanceTypesInput!
|
Includes the provider ID and an optional list of balance type IDs. |
Example
Query
query getBalanceTypes($getBalanceTypesInput: GetBalanceTypesInput!) {
getBalanceTypes(getBalanceTypesInput: $getBalanceTypesInput) {
... on GetBalanceTypesPayload {
...GetBalanceTypesPayloadFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"getBalanceTypesInput": GetBalanceTypesInput}
Response
{"data": {"getBalanceTypes": GetBalanceTypesPayload}}
getClientCredentials
Description
Gets the client credentials for a specific client.
Authorized Roles: Tenant_Admin
Response
Returns a GetClientCredentialsResult!
Example
Query
query getClientCredentials(
$providerId: ID!,
$clientId: ID!
) {
getClientCredentials(
providerId: $providerId,
clientId: $clientId
) {
... on ClientCredentials {
...ClientCredentialsFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
... on ClientNotFound {
...ClientNotFoundFragment
}
}
}
Variables
{"providerId": 4, "clientId": 4}
Response
{"data": {"getClientCredentials": ClientCredentials}}
getCurrentUser
Description
Gets info for the currently logged in User. When used in an API context, this will return the API user.
Authorized Roles: All
Response
Returns a GetUserPayload
Example
Query
query getCurrentUser {
getCurrentUser {
providerId
userId
email
name
roleGroupMemberships
profilePicture {
...ProfilePhotoFragment
}
phoneNumber
jobTitle
softwareMfaEnabled
expiry
alertInterval
}
}
Response
{
"data": {
"getCurrentUser": {
"providerId": 4,
"userId": "4",
"email": AWSEmail,
"name": "xyz789",
"roleGroupMemberships": ["Account_Query"],
"profilePicture": ProfilePhoto,
"phoneNumber": AWSPhone,
"jobTitle": "xyz789",
"softwareMfaEnabled": true,
"expiry": AWSDateTime,
"alertInterval": 123
}
}
}
getDeployedFieldMappings
Description
Gets deployed field mappings for a provider sorted by when they will be applied.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher, Network_Operator, Network_Admin
Response
Returns a DeployedFieldMappingConnection
Example
Query
query getDeployedFieldMappings(
$providerId: ID!,
$first: Int!,
$after: String
) {
getDeployedFieldMappings(
providerId: $providerId,
first: $first,
after: $after
) {
edges {
...DeployedFieldMappingEdgeFragment
}
pageInfo {
...PageInfoFragment
}
}
}
Variables
{
"providerId": 4,
"first": 987,
"after": "xyz789"
}
Response
{
"data": {
"getDeployedFieldMappings": {
"edges": [DeployedFieldMappingEdge],
"pageInfo": PageInfo
}
}
}
getDevice
Description
Returns a Device for a provider by a device ID.
Authorized Roles: Account_Query, Account_Admin, Data_Admin
Response
Returns a DeviceResult
Example
Query
query getDevice(
$providerId: ID!,
$deviceId: ID!
) {
getDevice(
providerId: $providerId,
deviceId: $deviceId
) {
... on Device {
...DeviceFragment
}
... on DeviceNotFound {
...DeviceNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4, "deviceId": "4"}
Response
{"data": {"getDevice": Device}}
getEventDataRecordsByAccount
Description
Gets a list of event data records for an Account with pagination.
Authorized Roles: Data_Admin
Response
Returns an EventDataRecordAccountConnectionResult
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
accountId - ID!
|
Account ID. |
first - Int!
|
Returns the first n elements from the list or a maximum of 25. |
after - String
|
Returns the elements in the list that come after the specified cursor. |
filterBy - EventDataRecordFilter
|
Filtering options for event data records returned in the connection. |
Example
Query
query getEventDataRecordsByAccount(
$providerId: ID!,
$accountId: ID!,
$first: Int!,
$after: String,
$filterBy: EventDataRecordFilter
) {
getEventDataRecordsByAccount(
providerId: $providerId,
accountId: $accountId,
first: $first,
after: $after,
filterBy: $filterBy
) {
... on EventDataRecordAccountConnection {
...EventDataRecordAccountConnectionFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": "4",
"accountId": "4",
"first": 987,
"after": "abc123",
"filterBy": EventDataRecordFilter
}
Response
{
"data": {
"getEventDataRecordsByAccount": EventDataRecordAccountConnection
}
}
getEventDataRecordsByDevice
Description
Gets a list of event data records for a Device with pagination.
Authorized Roles: Data_Admin
Response
Returns an EventDataRecordDeviceConnectionResult
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
deviceId - ID!
|
Device ID. |
first - Int!
|
Returns the first n elements from the list or a maximum of 25. |
after - String
|
Returns the elements in the list that come after the specified cursor. |
filterBy - EventDataRecordFilter
|
Filtering options for event data records returned in the connection. |
Example
Query
query getEventDataRecordsByDevice(
$providerId: ID!,
$deviceId: ID!,
$first: Int!,
$after: String,
$filterBy: EventDataRecordFilter
) {
getEventDataRecordsByDevice(
providerId: $providerId,
deviceId: $deviceId,
first: $first,
after: $after,
filterBy: $filterBy
) {
... on EventDataRecordDeviceConnection {
...EventDataRecordDeviceConnectionFragment
}
... on DeviceNotFound {
...DeviceNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": 4,
"deviceId": 4,
"first": 987,
"after": "abc123",
"filterBy": EventDataRecordFilter
}
Response
{
"data": {
"getEventDataRecordsByDevice": EventDataRecordDeviceConnection
}
}
getFieldMappings
Description
Gets NOT deployed field mappings for a provider.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher, Network_Operator
Response
Returns a FieldMappingConnection
Example
Query
query getFieldMappings(
$providerId: ID!,
$first: Int!,
$after: String
) {
getFieldMappings(
providerId: $providerId,
first: $first,
after: $after
) {
edges {
...FieldMappingEdgeFragment
}
pageInfo {
...PageInfoFragment
}
}
}
Variables
{
"providerId": 4,
"first": 987,
"after": "abc123"
}
Response
{
"data": {
"getFieldMappings": {
"edges": [FieldMappingEdge],
"pageInfo": PageInfo
}
}
}
getLifecycle
Description
Gets a single lifecycle.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher
Response
Returns a GetLifecycleResult
Example
Query
query getLifecycle(
$providerId: ID!,
$lifecycleId: ID!
) {
getLifecycle(
providerId: $providerId,
lifecycleId: $lifecycleId
) {
... on Lifecycle {
...LifecycleFragment
}
... on LifecycleNotFound {
...LifecycleNotFoundFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": "4", "lifecycleId": 4}
Response
{"data": {"getLifecycle": Lifecycle}}
getLifecycles
Description
Gets a list of all lifecycles.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher
Response
Returns a GetLifecyclesResult
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
Example
Query
query getLifecycles($providerId: ID!) {
getLifecycles(providerId: $providerId) {
... on Lifecycles {
...LifecyclesFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4}
Response
{"data": {"getLifecycles": Lifecycles}}
getMyDashboard
Description
Gets the current user’s Dashboard information
Authorized Roles: Dashboard_Reader
Response
Returns a GetMyDashboardResult
Example
Query
query getMyDashboard {
getMyDashboard {
... on DashboardConfig {
...DashboardConfigFragment
}
... on FeatureNotEnabled {
...FeatureNotEnabledFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Response
{"data": {"getMyDashboard": DashboardConfig}}
getMyProviderConfig
Description
Gets tenant configuration of the logged in User.
Authorized Roles: All
Response
Returns a GetMyProviderConfigResult
Example
Query
query getMyProviderConfig {
getMyProviderConfig {
... on ProviderConfig {
...ProviderConfigFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Response
{"data": {"getMyProviderConfig": ProviderConfig}}
getMyRestoreJobs
Description
Gets restore jobs of the current tenant.
Authorized Roles: Tenant_Admin
Response
Returns a GetMyRestoreJobsResult
Arguments
| Name | Description |
|---|---|
getMyRestoreJobsInput - GetMyRestoreJobsInput!
|
Example
Query
query getMyRestoreJobs($getMyRestoreJobsInput: GetMyRestoreJobsInput!) {
getMyRestoreJobs(getMyRestoreJobsInput: $getMyRestoreJobsInput) {
... on GetMyRestoreJobsPayload {
...GetMyRestoreJobsPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"getMyRestoreJobsInput": GetMyRestoreJobsInput}
Response
{"data": {"getMyRestoreJobs": GetMyRestoreJobsPayload}}
getPlan
Description
Gets a Plan for a provider by a plan ID.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher
Response
Returns a PlanResult
Example
Query
query getPlan(
$providerId: ID!,
$planId: ID!
) {
getPlan(
providerId: $providerId,
planId: $planId
) {
... on Plan {
...PlanFragment
}
... on PlanNotFound {
...PlanNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": "4", "planId": 4}
Response
{"data": {"getPlan": Plan}}
getPlanVersion
Description
Gets a Plan Version for a provider by a plan version ID.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher
Response
Returns a PlanVersionResult
Example
Query
query getPlanVersion(
$providerId: ID!,
$planVersionId: ID!
) {
getPlanVersion(
providerId: $providerId,
planVersionId: $planVersionId
) {
... on PlanVersion {
...PlanVersionFragment
}
... on SimplePlanVersion {
...SimplePlanVersionFragment
}
... on RecurringPlanVersion {
...RecurringPlanVersionFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4, "planVersionId": 4}
Response
{"data": {"getPlanVersion": PlanVersion}}
getPlans
Description
Gets a list of plans for a provider with pagination.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher
Response
Returns a PlanConnection
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
first - Int!
|
Returns the first n elements from the list or a maximum of 25. |
after - String
|
Returns the elements in the list that come after the specified cursor. |
orderBy - PlanOrder
|
Ordering options for plans returned from the connection. |
Example
Query
query getPlans(
$providerId: ID!,
$first: Int!,
$after: String,
$orderBy: PlanOrder
) {
getPlans(
providerId: $providerId,
first: $first,
after: $after,
orderBy: $orderBy
) {
edges {
...PlanEdgeFragment
}
pageInfo {
...PageInfoFragment
}
}
}
Variables
{
"providerId": 4,
"first": 987,
"after": "xyz789",
"orderBy": PlanOrder
}
Response
{
"data": {
"getPlans": {
"edges": [PlanEdge],
"pageInfo": PageInfo
}
}
}
getQoSProfile
Description
Gets a QoS Profile for a provider by profile ID.
Authorized Roles: Plan_Designer
Response
Returns an GetQoSProfileResult
Example
Query
query getQoSProfile(
$providerId: ID!,
$id: ID!
) {
getQoSProfile(
providerId: $providerId,
id: $id
) {
... on QoSProfile {
...QoSProfileFragment
}
... on QoSProfileNotFound {
...QoSProfileNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4, "id": "4"}
Response
{"data": {"getQoSProfile": QoSProfile}}
getQoSProfiles
Description
Gets all QoS Profiles for a provider with pagination support.
Authorized Roles: Plan_Designer
Response
Returns an GetQoSProfilesResult
Example
Query
query getQoSProfiles(
$providerId: ID!,
$first: Int,
$after: String
) {
getQoSProfiles(
providerId: $providerId,
first: $first,
after: $after
) {
... on QoSProfileConnection {
...QoSProfileConnectionFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": 4,
"first": 25,
"after": "xyz789"
}
Response
{"data": {"getQoSProfiles": QoSProfileConnection}}
getRatingGroupHierarchy
Description
Gets Rating Group hierarchy for a provider.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher, Network_Admin
Response
Returns a RatingGroupResult
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
Example
Query
query getRatingGroupHierarchy($providerId: ID!) {
getRatingGroupHierarchy(providerId: $providerId) {
... on RatingGroup {
...RatingGroupFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4}
Response
{"data": {"getRatingGroupHierarchy": RatingGroup}}
getRelatedAccountsByDevice
Description
Gets a list of all parent accounts for a provided device ID.
Authorized Roles:Account_Query, Account_Admin,Data_Admin
Response
Returns a GetRelatedAccountsByDeviceResult
Example
Query
query getRelatedAccountsByDevice(
$providerId: ID!,
$deviceId: ID!
) {
getRelatedAccountsByDevice(
providerId: $providerId,
deviceId: $deviceId
) {
... on GetRelatedAccountsByDevicePayload {
...GetRelatedAccountsByDevicePayloadFragment
}
... on DeviceNotFound {
...DeviceNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4, "deviceId": 4}
Response
{
"data": {
"getRelatedAccountsByDevice": GetRelatedAccountsByDevicePayload
}
}
getSGSNTable
Description
Gets the SGSN table for a provider.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher, Network_Operator
Response
Returns an SGSNTableResult
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
Example
Query
query getSGSNTable($providerId: ID!) {
getSGSNTable(providerId: $providerId) {
... on SGSNTable {
...SGSNTableFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": "4"}
Response
{"data": {"getSGSNTable": SGSNTable}}
getSettings
Description
Gets settings for a provider.
Authorized Roles: Plan_Query, Plan_Designer, Plan_Publisher, Plan_Admin
Response
Returns a SettingsResult
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
Example
Query
query getSettings($providerId: ID!) {
getSettings(providerId: $providerId) {
... on Settings {
...SettingsFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4}
Response
{"data": {"getSettings": Settings}}
getUser
Description
Gets a User for a given provider ID and user ID, or returns a UserNotFound error.
Authorized Roles: Tenant_Admin
Response
Returns a GetUserResult
Arguments
| Name | Description |
|---|---|
getUserInput - GetUserInput!
|
Get user input |
Example
Query
query getUser($getUserInput: GetUserInput!) {
getUser(getUserInput: $getUserInput) {
... on GetUserPayload {
...GetUserPayloadFragment
}
... on UserNotFound {
...UserNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"getUserInput": GetUserInput}
Response
{"data": {"getUser": GetUserPayload}}
listAllClientCredentials
Description
Gets all the client credentials for a specific provider.
Authorized Roles: Tenant_Admin
Response
Returns a ListAllClientCredentialsResult!
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID |
Example
Query
query listAllClientCredentials($providerId: ID!) {
listAllClientCredentials(providerId: $providerId) {
... on ListAllClientCredentialsPayload {
...ListAllClientCredentialsPayloadFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": "4"}
Response
{
"data": {
"listAllClientCredentials": ListAllClientCredentialsPayload
}
}
listUsers
Description
Lists the users for the given provider ID.
Authorized Roles: Tenant_Admin
Response
Returns a ListUsersResult
Example
Query
query listUsers(
$providerId: ID!,
$first: Int!,
$after: String
) {
listUsers(
providerId: $providerId,
first: $first,
after: $after
) {
... on ListUsersConnection {
...ListUsersConnectionFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": 4,
"first": 987,
"after": "abc123"
}
Response
{"data": {"listUsers": ListUsersConnection}}
Mutations
archivePlanVersion
Description
Archives a Plan Version if it is suspended with no subscribed accounts.
Authorized Roles: Plan_Designer
Response
Returns an ArchivePlanVersionResult!
Arguments
| Name | Description |
|---|---|
input - ArchivePlanVersionInput!
|
Parameters for DeletePlanVersion. |
Example
Query
mutation archivePlanVersion($input: ArchivePlanVersionInput!) {
archivePlanVersion(input: $input) {
... on ArchivePlanVersionPayload {
...ArchivePlanVersionPayloadFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on PlanVersionWrongTransition {
...PlanVersionWrongTransitionFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": ArchivePlanVersionInput}
Response
{
"data": {
"archivePlanVersion": ArchivePlanVersionPayload
}
}
cancelPlanSubscription
Description
Cancels existing assignment of a Plan to an Account.
- Uses the
planSubscriptionIdto identify the correct plan. - Balances from the Plan remain after cancellation.
Authorized Roles: Account_Admin
Response
Returns a CancelPlanVersionSubscriptionResult!
Arguments
| Name | Description |
|---|---|
input - CancelPlanSubscriptionInput!
|
Parameters for CancelPlanSubscription. |
Example
Query
mutation cancelPlanSubscription($input: CancelPlanSubscriptionInput!) {
cancelPlanSubscription(input: $input) {
... on CancelPlanVersionSubscriptionPayload {
...CancelPlanVersionSubscriptionPayloadFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on SubscriptionNotFound {
...SubscriptionNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
}
}
Variables
{"input": CancelPlanSubscriptionInput}
Response
{
"data": {
"cancelPlanSubscription": CancelPlanVersionSubscriptionPayload
}
}
createAccount
Description
Creates an Account for a provider.
Authorized Roles: Account_Admin
Response
Returns a CreateAccountResult!
Arguments
| Name | Description |
|---|---|
input - CreateAccountInput!
|
Parameters for CreateAccount. |
Example
Query
mutation createAccount($input: CreateAccountInput!) {
createAccount(input: $input) {
... on CreateAccountPayload {
...CreateAccountPayloadFragment
}
... on TransactionHasBeenProcessed {
...TransactionHasBeenProcessedFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on AccountAlreadyExists {
...AccountAlreadyExistsFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on LifecycleNotFound {
...LifecycleNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PostpaidFieldInPrepaidAccount {
...PostpaidFieldInPrepaidAccountFragment
}
... on PostpaidPropertiesRequired {
...PostpaidPropertiesRequiredFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreateAccountInput}
Response
{"data": {"createAccount": CreateAccountPayload}}
createBalance
Description
Creates a new balance for the provider.
Response
Returns a CreateBalanceResult
Arguments
| Name | Description |
|---|---|
input - CreateBalanceInput!
|
Payload with provider ID and balance information. |
Example
Query
mutation createBalance($input: CreateBalanceInput!) {
createBalance(input: $input) {
... on BalancePayload {
...BalancePayloadFragment
}
... on TransactionHasBeenProcessed {
...TransactionHasBeenProcessedFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreateBalanceInput}
Response
{"data": {"createBalance": BalancePayload}}
createBalanceType
Description
Creates a new balance type for the provider.
Response
Returns a CreateBalanceTypeResult
Arguments
| Name | Description |
|---|---|
input - CreateBalanceTypeInput!
|
Payload with provider ID and balance type information. |
Example
Query
mutation createBalanceType($input: CreateBalanceTypeInput!) {
createBalanceType(input: $input) {
... on BalanceTypePayload {
...BalanceTypePayloadFragment
}
... on BalanceTypeNameInUse {
...BalanceTypeNameInUseFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreateBalanceTypeInput}
Response
{"data": {"createBalanceType": BalanceTypePayload}}
createClientCredentials
Description
Creates a new Client with client credentials.
Authorized Roles: Tenant_Admin
Response
Returns a CreateClientCredentialsResult!
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
|
input - CreateClientCredentialsInput!
|
Example
Query
mutation createClientCredentials(
$providerId: ID!,
$input: CreateClientCredentialsInput!
) {
createClientCredentials(
providerId: $providerId,
input: $input
) {
... on CreateClientCredentialsPayload {
...CreateClientCredentialsPayloadFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on ClientCreationLimitExceeded {
...ClientCreationLimitExceededFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": 4, "input": CreateClientCredentialsInput}
Response
{
"data": {
"createClientCredentials": CreateClientCredentialsPayload
}
}
createDevice
Description
Creates a Device in an Account.
Authorized Roles: Account_Admin
Response
Returns a CreateDeviceResult!
Arguments
| Name | Description |
|---|---|
input - CreateDeviceInput!
|
Parameters for CreateDevice. |
Example
Query
mutation createDevice($input: CreateDeviceInput!) {
createDevice(input: $input) {
... on CreateDevicePayload {
...CreateDevicePayloadFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on DeviceAlreadyExists {
...DeviceAlreadyExistsFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreateDeviceInput}
Response
{"data": {"createDevice": CreateDevicePayload}}
createFieldMapping
Description
Creates a Field Mapping in draft. Draft field mappings need to be deployed using deployFieldMappings to become effective.
Authorized Roles: Network_Operator, Plan_Publisher
Response
Returns a CreateFieldMappingResult!
Arguments
| Name | Description |
|---|---|
input - CreateFieldMappingInput!
|
Parameters for CreateFieldMapping. |
Example
Query
mutation createFieldMapping($input: CreateFieldMappingInput!) {
createFieldMapping(input: $input) {
... on CreateFieldMappingPayload {
...CreateFieldMappingPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on FieldMappingAlreadyExists {
...FieldMappingAlreadyExistsFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreateFieldMappingInput}
Response
{
"data": {
"createFieldMapping": CreateFieldMappingPayload
}
}
createLifecycle
Description
Creates a lifecycle.
Authorized Roles: Plan_Designer, Plan_Publisher
Response
Returns a CreateLifecycleResult
Arguments
| Name | Description |
|---|---|
input - CreateLifecycleInput!
|
Example
Query
mutation createLifecycle($input: CreateLifecycleInput!) {
createLifecycle(input: $input) {
... on LifecyclePayload {
...LifecyclePayloadFragment
}
... on InvalidNumberOfStates {
...InvalidNumberOfStatesFragment
}
... on InvalidStateTransitions {
...InvalidStateTransitionsFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
... on InvalidField {
...InvalidFieldFragment
}
}
}
Variables
{"input": CreateLifecycleInput}
Response
{"data": {"createLifecycle": LifecyclePayload}}
createPlan
Description
Creates a Plan for a provider.
This mutation is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out.
Authorized Roles: Plan_Designer
Response
Returns a CreatePlanResult!
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
input - PlanInput!
|
Parameters for CreatePlan. |
Example
Query
mutation createPlan(
$providerId: ID!,
$input: PlanInput!
) {
createPlan(
providerId: $providerId,
input: $input
) {
... on PlanPayload {
...PlanPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on PlanAlreadyExists {
...PlanAlreadyExistsFragment
}
... on PlanServiceValidationFailed {
...PlanServiceValidationFailedFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": "4",
"input": PlanInput
}
Response
{"data": {"createPlan": PlanPayload}}
createPlanFromInitialRecurringFirstUsageTemplate
Description
Creates a plan by using a template.
Response
Returns a CreatePlanFromInitialTemplateResult!
Arguments
| Name | Description |
|---|---|
input - CreatePlanFromInitialRecurringFirstUsageTemplateInput!
|
Parameters for CreatePlanFromInitialRecurringFirstUsageTemplate. |
Example
Query
mutation createPlanFromInitialRecurringFirstUsageTemplate($input: CreatePlanFromInitialRecurringFirstUsageTemplateInput!) {
createPlanFromInitialRecurringFirstUsageTemplate(input: $input) {
... on CreatePlanPayload {
...CreatePlanPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PlanAlreadyExists {
...PlanAlreadyExistsFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on CreatePlanValidationFailed {
...CreatePlanValidationFailedFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on ServiceFormatError {
...ServiceFormatErrorFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"input": CreatePlanFromInitialRecurringFirstUsageTemplateInput
}
Response
{
"data": {
"createPlanFromInitialRecurringFirstUsageTemplate": CreatePlanPayload
}
}
createPlanFromInitialTemplate
Description
Creates a Plan by using a template.
Authorized Roles: Plan_Designer
Response
Returns a CreatePlanFromInitialTemplateResult!
Arguments
| Name | Description |
|---|---|
input - CreatePlanFromInitialTemplateInput!
|
Parameters for CreatePlanFromInitialTemplate. |
Example
Query
mutation createPlanFromInitialTemplate($input: CreatePlanFromInitialTemplateInput!) {
createPlanFromInitialTemplate(input: $input) {
... on CreatePlanPayload {
...CreatePlanPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PlanAlreadyExists {
...PlanAlreadyExistsFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on CreatePlanValidationFailed {
...CreatePlanValidationFailedFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on ServiceFormatError {
...ServiceFormatErrorFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreatePlanFromInitialTemplateInput}
Response
{
"data": {
"createPlanFromInitialTemplate": CreatePlanPayload
}
}
createPlanVersionFromInitialRecurringFirstUsageTemplate
Description
Updates a plan that was created by using a template. Creates a new version of the plan.
Response
Arguments
| Name | Description |
|---|---|
input - CreatePlanVersionFromInitialRecurringFirstUsageTemplateInput!
|
Parameters for CreatePlanVersionFromInitialRecurringFirstUsageTemplate. |
Example
Query
mutation createPlanVersionFromInitialRecurringFirstUsageTemplate($input: CreatePlanVersionFromInitialRecurringFirstUsageTemplateInput!) {
createPlanVersionFromInitialRecurringFirstUsageTemplate(input: $input) {
... on PlanVersionPayload {
...PlanVersionPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on CreatePlanValidationFailed {
...CreatePlanValidationFailedFragment
}
... on PlanVersionAlreadyExists {
...PlanVersionAlreadyExistsFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on ServiceFormatError {
...ServiceFormatErrorFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"input": CreatePlanVersionFromInitialRecurringFirstUsageTemplateInput
}
Response
{
"data": {
"createPlanVersionFromInitialRecurringFirstUsageTemplate": PlanVersionPayload
}
}
createPlanVersionFromInitialTemplate
Description
Creates a new Plan Version of a Plan that was originally created by using createPlanFromInitialTemplate.
Authorized Roles: Plan_Designer
Response
Arguments
| Name | Description |
|---|---|
input - CreatePlanVersionFromInitialTemplateInput!
|
Parameters for CreatePlanVersionFromInitialTemplate. |
Example
Query
mutation createPlanVersionFromInitialTemplate($input: CreatePlanVersionFromInitialTemplateInput!) {
createPlanVersionFromInitialTemplate(input: $input) {
... on PlanVersionPayload {
...PlanVersionPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on CreatePlanValidationFailed {
...CreatePlanValidationFailedFragment
}
... on PlanVersionAlreadyExists {
...PlanVersionAlreadyExistsFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on ServiceFormatError {
...ServiceFormatErrorFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreatePlanVersionFromInitialTemplateInput}
Response
{
"data": {
"createPlanVersionFromInitialTemplate": PlanVersionPayload
}
}
createQoSProfile
Description
Creates a QoS Profile for a provider.
Authorized Roles: Plan_Designer
Response
Returns an CreateQoSProfileResult!
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
input - QoSProfileInput!
|
Parameters for createQoSProfile. |
Example
Query
mutation createQoSProfile(
$providerId: ID!,
$input: QoSProfileInput!
) {
createQoSProfile(
providerId: $providerId,
input: $input
) {
... on CreateQoSProfilePayload {
...CreateQoSProfilePayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": "4",
"input": QoSProfileInput
}
Response
{"data": {"createQoSProfile": CreateQoSProfilePayload}}
createUser
Description
Creates a tenant User.
Authorized Roles: Tenant_Admin
Response
Returns a CreateUserResult!
Arguments
| Name | Description |
|---|---|
input - CreateUserInput!
|
Parameters for CreateUser. |
Example
Query
mutation createUser($input: CreateUserInput!) {
createUser(input: $input) {
... on SaveUserPayload {
...SaveUserPayloadFragment
}
... on UserAlreadyExists {
...UserAlreadyExistsFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": CreateUserInput}
Response
{"data": {"createUser": SaveUserPayload}}
deleteAccount
Description
Deletes an Account if it does not have any children or devices.
Authorized Roles: Account_Admin
Response
Returns a DeleteAccountResult!
Arguments
| Name | Description |
|---|---|
input - DeleteAccountInput!
|
Parameters for DeleteAccount. |
Example
Query
mutation deleteAccount($input: DeleteAccountInput!) {
deleteAccount(input: $input) {
... on DeleteAccountPayload {
...DeleteAccountPayloadFragment
}
... on TransactionHasBeenProcessed {
...TransactionHasBeenProcessedFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on AccountHasReferences {
...AccountHasReferencesFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteAccountInput}
Response
{"data": {"deleteAccount": DeleteAccountPayload}}
deleteAccountBalanceTypeCounter
Description
Delete a Balance Type Counter for an account based on the provided input parameters.
Response
Returns a DeleteAccountBalanceTypeCounterResult
Arguments
| Name | Description |
|---|---|
input - DeleteAccountBalanceTypeCounterInput!
|
Example
Query
mutation deleteAccountBalanceTypeCounter($input: DeleteAccountBalanceTypeCounterInput!) {
deleteAccountBalanceTypeCounter(input: $input) {
... on DeleteAccountBalanceTypeCounterPayload {
...DeleteAccountBalanceTypeCounterPayloadFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on AccountBalanceTypeCounterNotFound {
...AccountBalanceTypeCounterNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteAccountBalanceTypeCounterInput}
Response
{
"data": {
"deleteAccountBalanceTypeCounter": DeleteAccountBalanceTypeCounterPayload
}
}
deleteBalance
Description
Deletes an existing balance for the provider.
Response
Returns a DeleteBalanceResult
Arguments
| Name | Description |
|---|---|
input - DeleteBalanceInput!
|
Payload with provider ID and balance ID. |
Example
Query
mutation deleteBalance($input: DeleteBalanceInput!) {
deleteBalance(input: $input) {
... on DeleteBalancePayload {
...DeleteBalancePayloadFragment
}
... on TransactionHasBeenProcessed {
...TransactionHasBeenProcessedFragment
}
... on BalanceNotFound {
...BalanceNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on BalanceHasReferences {
...BalanceHasReferencesFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteBalanceInput}
Response
{"data": {"deleteBalance": DeleteBalancePayload}}
deleteBalanceType
Description
Deletes an existing balance type for the provider.
Response
Returns a DeleteBalanceTypeResult
Arguments
| Name | Description |
|---|---|
input - DeleteBalanceTypeInput!
|
Payload with provider ID and balance type ID. |
Example
Query
mutation deleteBalanceType($input: DeleteBalanceTypeInput!) {
deleteBalanceType(input: $input) {
... on DeleteBalanceTypePayload {
...DeleteBalanceTypePayloadFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on BalanceTypeHasReferences {
...BalanceTypeHasReferencesFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteBalanceTypeInput}
Response
{"data": {"deleteBalanceType": DeleteBalanceTypePayload}}
deleteBalanceTypeCounter
Description
Delete a Balance Type Counter based on the provided input parameters.
Response
Returns a DeleteBalanceTypeCounterResult
Arguments
| Name | Description |
|---|---|
input - DeleteBalanceTypeCounterInput!
|
Example
Query
mutation deleteBalanceTypeCounter($input: DeleteBalanceTypeCounterInput!) {
deleteBalanceTypeCounter(input: $input) {
... on DeleteBalanceTypeCounterPayload {
...DeleteBalanceTypeCounterPayloadFragment
}
... on BalanceTypeCounterNotFound {
...BalanceTypeCounterNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteBalanceTypeCounterInput}
Response
{
"data": {
"deleteBalanceTypeCounter": DeleteBalanceTypeCounterPayload
}
}
deleteClientCredentials
Description
Deletes a Client credentials.
Authorized Roles: Tenant_Admin
Response
Returns a DeleteClientCredentialsResult!
Example
Query
mutation deleteClientCredentials(
$providerId: ID!,
$clientId: ID!
) {
deleteClientCredentials(
providerId: $providerId,
clientId: $clientId
) {
... on DeleteClientCredentialsPayload {
...DeleteClientCredentialsPayloadFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on ClientNotFound {
...ClientNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"providerId": "4", "clientId": 4}
Response
{
"data": {
"deleteClientCredentials": DeleteClientCredentialsPayload
}
}
deleteDevice
Description
Deletes a Device from an Account.
Authorized Roles: Account_Admin
Response
Returns a DeleteDeviceResult!
Arguments
| Name | Description |
|---|---|
input - DeleteDeviceInput!
|
Parameters for DeleteDevice. |
Example
Query
mutation deleteDevice($input: DeleteDeviceInput!) {
deleteDevice(input: $input) {
... on DeleteDevicePayload {
...DeleteDevicePayloadFragment
}
... on DeviceNotFound {
...DeviceNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteDeviceInput}
Response
{"data": {"deleteDevice": DeleteDevicePayload}}
deleteFieldMapping
Description
Deletes a Field Mapping in draft. Draft field mappings need to be deployed using deployFieldMappings to become effective.
Authorized Roles: Network_Operator, Plan_Publisher
Response
Returns a DeleteFieldMappingResult!
Arguments
| Name | Description |
|---|---|
input - DeleteFieldMappingInput!
|
Parameters for DeleteFieldMapping. |
Example
Query
mutation deleteFieldMapping($input: DeleteFieldMappingInput!) {
deleteFieldMapping(input: $input) {
... on DeleteFieldMappingPayload {
...DeleteFieldMappingPayloadFragment
}
... on FieldMappingNotFound {
...FieldMappingNotFoundFragment
}
... on FieldMappingHasReferences {
...FieldMappingHasReferencesFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteFieldMappingInput}
Response
{
"data": {
"deleteFieldMapping": DeleteFieldMappingPayload
}
}
deleteLifecycle
Description
Deletes a lifecycle.
Authorized Roles: Plan_Designer, Plan_Publisher
Response
Returns a DeleteLifecycleResult
Arguments
| Name | Description |
|---|---|
input - DeleteLifecycleInput!
|
Example
Query
mutation deleteLifecycle($input: DeleteLifecycleInput!) {
deleteLifecycle(input: $input) {
... on DeleteLifecyclePayload {
...DeleteLifecyclePayloadFragment
}
... on LifecycleNotFound {
...LifecycleNotFoundFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteLifecycleInput}
Response
{"data": {"deleteLifecycle": DeleteLifecyclePayload}}
deletePlan
Description
Deletes a Plan. Deployed plans cannot be deleted but its plan versions can be archived using archivePlanVersion.
This mutation is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out.
Authorized Roles: Plan_Designer
Response
Returns a DeletePlanResult!
Arguments
| Name | Description |
|---|---|
providerId - ID
|
Service provider ID for BETA API. |
planId - ID
|
The unique identifier of the plan to delete for BETA API. |
input - DeletePlanInput
|
Parameters for DeletePlan. Important: This input is deprecated, specify it in the argument list instead. Deprecated date is 2025-06-01. Expiration date is 2025-09-01. |
Example
Query
mutation deletePlan(
$providerId: ID,
$planId: ID,
$input: DeletePlanInput
) {
deletePlan(
providerId: $providerId,
planId: $planId,
input: $input
) {
... on DeletePlanPayload {
...DeletePlanPayloadFragment
}
... on PlanNotFound {
...PlanNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PlanVersionHasReferences {
...PlanVersionHasReferencesFragment
}
... on PlanIsReadOnly {
...PlanIsReadOnlyFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": "4",
"planId": 4,
"input": DeletePlanInput
}
Response
{"data": {"deletePlan": DeletePlanPayload}}
deletePlanVersion
Description
Deletes a Plan Version if it was never deployed.
Authorized Roles: Plan_Designer
Response
Returns a DeletePlanVersionResult!
Arguments
| Name | Description |
|---|---|
input - DeletePlanVersionInput!
|
Parameters for DeletePlanVersion. |
Example
Query
mutation deletePlanVersion($input: DeletePlanVersionInput!) {
deletePlanVersion(input: $input) {
... on DeletePlanVersionPayload {
...DeletePlanVersionPayloadFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on PlanVersionHasReferences {
...PlanVersionHasReferencesFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeletePlanVersionInput}
Response
{"data": {"deletePlanVersion": DeletePlanVersionPayload}}
deleteQoSProfile
Description
Deletes a QoS Profile for a provider. The profile cannot be deleted if it is referenced by any plan versions.
Authorized Roles: Plan_Designer
Response
Returns an DeleteQoSProfileResult!
Example
Query
mutation deleteQoSProfile(
$providerId: ID!,
$id: ID!
) {
deleteQoSProfile(
providerId: $providerId,
id: $id
) {
... on DeleteQoSProfilePayload {
...DeleteQoSProfilePayloadFragment
}
... on QoSProfileNotFound {
...QoSProfileNotFoundFragment
}
... on QoSProfileInUse {
...QoSProfileInUseFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": "4",
"id": "4"
}
Response
{"data": {"deleteQoSProfile": DeleteQoSProfilePayload}}
deleteUser
Description
Deletes a tenant User.
Authorized Roles: Tenant_Admin
Response
Returns a DeleteUserResult!
Arguments
| Name | Description |
|---|---|
input - DeleteUserInput!
|
Parameters for DeleteUser. |
Example
Query
mutation deleteUser($input: DeleteUserInput!) {
deleteUser(input: $input) {
... on DeleteUserPayload {
...DeleteUserPayloadFragment
}
... on UserNotFound {
...UserNotFoundFragment
}
... on UserIsReadOnly {
...UserIsReadOnlyFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeleteUserInput}
Response
{"data": {"deleteUser": DeleteUserPayload}}
deployFieldMappings
Description
Once you have defined a new Field Mapping, you can call deployFieldMappings and specify the path of the field mapping you want to deploy.
- By providing a
fromdate, you can specify a point in the future when current set of field mappings will take effect, e.g. the first of the coming month for the field mapping to become active. - If you omit the
fromdate, immediate activation is performed. - The process to deploy an updated field mapping is equivalent to a new one. You specify the path of the field mapping you want to deploy and this specific mapping will be updated. Any other deployed mappings remain untouched.
- If you provide a list of
paths, this set of field mappings will be deployed. Any other deployed mappings remain unchanged. - To remove a deployed Field Mapping: - Delete the Field Mapping from the draft using
deleteFieldMapping. - Next invoke thedeployFieldMappingswithout providing thepathsparameter. - This operation will deploy only the field mappings that are specified in the draft. - If afromdate is not provided, the current time is used as the defaultfromdate. - Any existing field mappings not in the draft will be removed with the following limitations. When existing field mappings are deleted, the system checks if thefromdate of the existing mapping is earlier than thefromdate specified for the new mapping. If it is, the deleted mapping is re-added. So to completely delete a deployed field mapping, you should provide afromdate that matches or precedes thefromdate used in the prior deployment of the field mapping you wish to remove.
Authorized Roles: Network_Admin, Plan_Publisher
Response
Returns a DeployFieldMappingsResult!
Arguments
| Name | Description |
|---|---|
input - DeployFieldMappingsInput!
|
Parameters for DeployFieldMappings. |
Example
Query
mutation deployFieldMappings($input: DeployFieldMappingsInput!) {
deployFieldMappings(input: $input) {
... on DeployFieldMappingsPayload {
...DeployFieldMappingsPayloadFragment
}
... on FieldMappingNotFound {
...FieldMappingNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeployFieldMappingsInput}
Response
{
"data": {
"deployFieldMappings": DeployFieldMappingsPayload
}
}
deployPlan
Description
Deploys a Plan so it can be subscribed by accounts. A deployed plan cannot be updated anymore.
Authorized Roles: Plan_Publisher
Response
Returns a DeployPlanVersionResult!
Arguments
| Name | Description |
|---|---|
input - DeployPlanVersionInput!
|
Parameters for DeployPlan. |
Example
Query
mutation deployPlan($input: DeployPlanVersionInput!) {
deployPlan(input: $input) {
... on PlanVersionPayload {
...PlanVersionPayloadFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on DeploymentVerificationFailed {
...DeploymentVerificationFailedFragment
}
... on MigrationAlreadyInProgress {
...MigrationAlreadyInProgressFragment
}
... on PlanVersionWrongTransition {
...PlanVersionWrongTransitionFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": DeployPlanVersionInput}
Response
{"data": {"deployPlan": PlanVersionPayload}}
makePlanAssignable
Description
Makes a Plan assignable so it can be subscribed by accounts. Plan must be deployed to be able to make it assignable.
Authorized Roles: Plan_Publisher
Response
Returns an AssignablePlanVersionResult!
Arguments
| Name | Description |
|---|---|
input - AssignablePlanVersionInput!
|
Parameters for MakePlanAssignable. |
revert - Boolean
|
Makes a Plan NOT assignable. It can be done at any point in time to make sure that a Plan cannot be subscribed by accounts. |
Example
Query
mutation makePlanAssignable(
$input: AssignablePlanVersionInput!,
$revert: Boolean
) {
makePlanAssignable(
input: $input,
revert: $revert
) {
... on PlanVersionPayload {
...PlanVersionPayloadFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on PlanVersionWrongTransition {
...PlanVersionWrongTransitionFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": AssignablePlanVersionInput, "revert": true}
Response
{"data": {"makePlanAssignable": PlanVersionPayload}}
makePlanNotAssignable
Description
Makes a Plan NOT assignable. It can be done at any point in time to make sure that a Plan cannot be subscribed by accounts.
Important: This mutation is deprecated. Use makePlanAssignable with revert: true instead. Deprecated date is 2024-10-31. Expiration date is 2025-01-31.
Authorized Roles: Plan_Publisher
Response
Returns an AssignablePlanVersionResult!
Arguments
| Name | Description |
|---|---|
input - AssignablePlanVersionInput!
|
Parameters for MakePlanNotAssignable. |
Example
Query
mutation makePlanNotAssignable($input: AssignablePlanVersionInput!) {
makePlanNotAssignable(input: $input) {
... on PlanVersionPayload {
...PlanVersionPayloadFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on PlanVersionWrongTransition {
...PlanVersionWrongTransitionFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": AssignablePlanVersionInput}
Response
{"data": {"makePlanNotAssignable": PlanVersionPayload}}
resetUserPassword
Description
Resets the password of a given User.
Authorized Roles: Tenant_Admin
Response
Returns a ResetUserPasswordResult!
Arguments
| Name | Description |
|---|---|
input - ResetUserPasswordInput!
|
Parameters for ResetUserPasswordInput |
Example
Query
mutation resetUserPassword($input: ResetUserPasswordInput!) {
resetUserPassword(input: $input) {
... on ResetUserPasswordPayload {
...ResetUserPasswordPayloadFragment
}
... on UserNotFound {
...UserNotFoundFragment
}
... on UserIncorrectStatus {
...UserIncorrectStatusFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": ResetUserPasswordInput}
Response
{"data": {"resetUserPassword": ResetUserPasswordPayload}}
subscribeToPlan
Description
Assigns a Plan to an Account for a predefined period of time. If the from parameter is not specified, the plan starts immediately. If the to parameter is not specified, the plan continues indefinitely for recurring plans, or until the end of the plan period for non-recurring plans.
When subscribing to a plan, provide one of the following identifiers:
- planVersionId: The unique identifier of a specific version of a plan. Use this when you need to enforce a particular plan version without automatic updates.
- planId: The unique identifier of a plan. This is the preferred method as it ensures that the subscription is continuously updated to the latest active version of the plan, reducing the need for manual interventions. If provided, the subscription will apply the current active version of the specified plan deployed with an alias. This means, if there is no active version of the plan at the time of the API call,
SubscribeToPlanwill raise an error even if the subscription is for a future date.
Authorized Roles: Account_Admin
Response
Returns a SubscribeToPlanVersionResult!
Arguments
| Name | Description |
|---|---|
input - SubscribeToPlanVersionInput!
|
Parameters for SubscribeToPlan. |
Example
Query
mutation subscribeToPlan($input: SubscribeToPlanVersionInput!) {
subscribeToPlan(input: $input) {
... on SubscribeToPlanVersionPayload {
...SubscribeToPlanVersionPayloadFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on PlanVersionIsNotAssignable {
...PlanVersionIsNotAssignableFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on SubscriptionNotFound {
...SubscriptionNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on SubscribeToPlanVersionValidationFailed {
...SubscribeToPlanVersionValidationFailedFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on PlanNotFound {
...PlanNotFoundFragment
}
... on PlanAliasNotFound {
...PlanAliasNotFoundFragment
}
... on PlanAliasNotActive {
...PlanAliasNotActiveFragment
}
}
}
Variables
{"input": SubscribeToPlanVersionInput}
Response
{
"data": {
"subscribeToPlan": SubscribeToPlanVersionPayload
}
}
triggerRar
Description
Create RARs for all active sessions of an account.
Response
Returns a TriggerRarResult
Arguments
| Name | Description |
|---|---|
input - TriggerRarInput!
|
Payload with provider ID and account ID. |
Example
Query
mutation triggerRar($input: TriggerRarInput!) {
triggerRar(input: $input) {
... on TriggerRarPayload {
...TriggerRarPayloadFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on RarNotEnabled {
...RarNotEnabledFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": TriggerRarInput}
Response
{"data": {"triggerRar": TriggerRarPayload}}
updateAccount
Description
Updates Account attributes.
Authorized Roles: Account_Admin
Response
Returns an UpdateAccountResult!
Arguments
| Name | Description |
|---|---|
input - UpdateAccountInput!
|
Parameters for UpdateAccount. |
Example
Query
mutation updateAccount($input: UpdateAccountInput!) {
updateAccount(input: $input) {
... on UpdateAccountPayload {
...UpdateAccountPayloadFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on CannotChangeAccountType {
...CannotChangeAccountTypeFragment
}
... on PostpaidFieldInPrepaidAccount {
...PostpaidFieldInPrepaidAccountFragment
}
... on CannotSetLongFirstBillingCycle {
...CannotSetLongFirstBillingCycleFragment
}
... on DayOfMonthAlreadySet {
...DayOfMonthAlreadySetFragment
}
... on LifecycleNotFound {
...LifecycleNotFoundFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateAccountInput}
Response
{"data": {"updateAccount": UpdateAccountPayload}}
updateAccountBalanceTypeCounter
Description
Updates or creates a Balance Type Counter for an account based on the provided input parameters. If balanceTypeCounterId is specified, the new configuration will override the settings inherited from the associated BalanceType.
Note: A BalanceType Counter operates on the sum of all balances of the same BalanceType on the account, not on an individual balance.
Response
Returns an AccountBalanceTypeCounterResult
Arguments
| Name | Description |
|---|---|
input - UpdateAccountBalanceTypeCounterInput!
|
Example
Query
mutation updateAccountBalanceTypeCounter($input: UpdateAccountBalanceTypeCounterInput!) {
updateAccountBalanceTypeCounter(input: $input) {
... on AccountBalanceTypeCounterPayload {
...AccountBalanceTypeCounterPayloadFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on AccountBalanceTypeCounterNotFound {
...AccountBalanceTypeCounterNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateAccountBalanceTypeCounterInput}
Response
{
"data": {
"updateAccountBalanceTypeCounter": AccountBalanceTypeCounterPayload
}
}
updateArchivingPolicy
Description
Creates a lifecycle rule on EDR S3 bucket to move objects to Glacier store after a period of time.
Authorized Roles: Tenant_Admin
Response
Returns an UpdateArchivingPolicyResult!
Arguments
| Name | Description |
|---|---|
input - UpdateArchivingPolicyInput!
|
Parameters for UpdateArchivingPolicy. |
Example
Query
mutation updateArchivingPolicy($input: UpdateArchivingPolicyInput!) {
updateArchivingPolicy(input: $input) {
... on UpdateArchivingPolicyPayload {
...UpdateArchivingPolicyPayloadFragment
}
... on UpdateArchivingPolicyFailed {
...UpdateArchivingPolicyFailedFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateArchivingPolicyInput}
Response
{
"data": {
"updateArchivingPolicy": UpdateArchivingPolicyPayload
}
}
updateBalance
Description
Updates an existing balance for the provider.
Response
Returns an UpdateBalanceResult
Arguments
| Name | Description |
|---|---|
input - UpdateBalanceInput!
|
Payload with provider ID, balance ID, and fields to be updated. |
Example
Query
mutation updateBalance($input: UpdateBalanceInput!) {
updateBalance(input: $input) {
... on BalancePayload {
...BalancePayloadFragment
}
... on TransactionHasBeenProcessed {
...TransactionHasBeenProcessedFragment
}
... on BalanceNotFound {
...BalanceNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateBalanceInput}
Response
{"data": {"updateBalance": BalancePayload}}
updateBalanceType
Description
Updates an existing balance type for the provider.
Response
Returns an UpdateBalanceTypeResult
Arguments
| Name | Description |
|---|---|
input - UpdateBalanceTypeInput!
|
Payload with provider ID, balance type ID, and fields to be updated. |
Example
Query
mutation updateBalanceType($input: UpdateBalanceTypeInput!) {
updateBalanceType(input: $input) {
... on BalanceTypePayload {
...BalanceTypePayloadFragment
}
... on BalanceTypeNameInUse {
...BalanceTypeNameInUseFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on BalanceTypeHasReferences {
...BalanceTypeHasReferencesFragment
}
... on BalanceTypeCounterNotFound {
...BalanceTypeCounterNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateBalanceTypeInput}
Response
{"data": {"updateBalanceType": BalanceTypePayload}}
updateBalanceTypeCounter
Description
Update or create Balance Type Counter notifications based on the provided input parameters. Creates or updates BalanceTypeCounter.
Response
Returns a BalanceTypeCounterResult
Arguments
| Name | Description |
|---|---|
input - UpdateBalanceTypeCounterInput!
|
Example
Query
mutation updateBalanceTypeCounter($input: UpdateBalanceTypeCounterInput!) {
updateBalanceTypeCounter(input: $input) {
... on UpdateBalanceTypeCounterPayload {
...UpdateBalanceTypeCounterPayloadFragment
}
... on BalanceTypeCounterNotFound {
...BalanceTypeCounterNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateBalanceTypeCounterInput}
Response
{
"data": {
"updateBalanceTypeCounter": UpdateBalanceTypeCounterPayload
}
}
updateClientCredentials
Description
Updates the Client credentials.
Authorized Roles: Tenant_Admin
Response
Returns an UpdateClientCredentialsResult!
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
|
clientId - ID!
|
|
input - UpdateClientCredentialsInput!
|
Example
Query
mutation updateClientCredentials(
$providerId: ID!,
$clientId: ID!,
$input: UpdateClientCredentialsInput!
) {
updateClientCredentials(
providerId: $providerId,
clientId: $clientId,
input: $input
) {
... on ClientCredentials {
...ClientCredentialsFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on ClientNotFound {
...ClientNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": 4,
"clientId": "4",
"input": UpdateClientCredentialsInput
}
Response
{"data": {"updateClientCredentials": ClientCredentials}}
updateDevice
Description
Updates Device attributes.
Authorized Roles: Account_Admin
Response
Returns an UpdateDeviceResult!
Arguments
| Name | Description |
|---|---|
input - UpdateDeviceInput!
|
Parameters for UpdateDevice. |
Example
Query
mutation updateDevice($input: UpdateDeviceInput!) {
updateDevice(input: $input) {
... on UpdateDevicePayload {
...UpdateDevicePayloadFragment
}
... on DeviceNotFound {
...DeviceNotFoundFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateDeviceInput}
Response
{"data": {"updateDevice": UpdateDevicePayload}}
updateFieldMapping
Description
Updates a Field Mapping in draft. Draft field mappings need to be deployed using deployFieldMappings to become effective.
Authorized Roles: Network_Operator, Plan_Publisher
Response
Returns an UpdateFieldMappingResult!
Arguments
| Name | Description |
|---|---|
input - UpdateFieldMappingInput!
|
Parameters for UpdateFieldMapping. |
Example
Query
mutation updateFieldMapping($input: UpdateFieldMappingInput!) {
updateFieldMapping(input: $input) {
... on UpdateFieldMappingPayload {
...UpdateFieldMappingPayloadFragment
}
... on FieldMappingNotFound {
...FieldMappingNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateFieldMappingInput}
Response
{
"data": {
"updateFieldMapping": UpdateFieldMappingPayload
}
}
updateLifecycle
Description
Updates a lifecycle.
Authorized Roles: Plan_Designer, Plan_Publisher
Response
Returns an UpdateLifecycleResult
Arguments
| Name | Description |
|---|---|
input - UpdateLifecycleInput!
|
Example
Query
mutation updateLifecycle($input: UpdateLifecycleInput!) {
updateLifecycle(input: $input) {
... on LifecyclePayload {
...LifecyclePayloadFragment
}
... on LifecycleNotFound {
...LifecycleNotFoundFragment
}
... on InvalidNumberOfStates {
...InvalidNumberOfStatesFragment
}
... on InvalidStateTransitions {
...InvalidStateTransitionsFragment
}
... on ProviderNotFound {
...ProviderNotFoundFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
... on InvalidField {
...InvalidFieldFragment
}
}
}
Variables
{"input": UpdateLifecycleInput}
Response
{"data": {"updateLifecycle": LifecyclePayload}}
updateMyProviderConfig
Description
Updates config of the current tenant.
Authorized Roles: Tenant_Admin
Response
Returns an UpdateMyProviderConfigResult!
Arguments
| Name | Description |
|---|---|
input - UpdateMyProviderConfigInput!
|
Parameters for UpdateMyProviderConfig. |
Example
Query
mutation updateMyProviderConfig($input: UpdateMyProviderConfigInput!) {
updateMyProviderConfig(input: $input) {
... on ProviderConfig {
...ProviderConfigFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateMyProviderConfigInput}
Response
{"data": {"updateMyProviderConfig": ProviderConfig}}
updatePlan
Description
Updates attributes of a Plan, such as name.
This mutation is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out.
Authorized Roles: Plan_Designer
Response
Returns an UpdatePlanResult!
Arguments
| Name | Description |
|---|---|
providerId - ID
|
Service provider ID for BETA API. |
planId - ID
|
The unique identifier of the plan to update for BETA API. |
input - UpdatePlanInput!
|
Parameters for UpdatePlan. |
Example
Query
mutation updatePlan(
$providerId: ID,
$planId: ID,
$input: UpdatePlanInput!
) {
updatePlan(
providerId: $providerId,
planId: $planId,
input: $input
) {
... on PlanPayload {
...PlanPayloadFragment
}
... on UpdatePlanPayload {
...UpdatePlanPayloadFragment
}
... on PlanNotFound {
...PlanNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": 4,
"planId": "4",
"input": UpdatePlanInput
}
Response
{"data": {"updatePlan": PlanPayload}}
updatePlanSubscription
Description
Updates the properties of a Plan instance subscribed by an Account or switches the subscription to a different plan.
- Plan Switching: If
planIdorplanVersionIdis specified, the subscription will be switched to the corresponding plan. The switch is handled similarly to canceling the current plan and subscribing to a new one. - Plan Switching: If
planIdorplanVersionIdis specified, the subscription will be switched to the corresponding plan. The switch is handled similarly to canceling the current plan and subscribing to a new one but without charging the new plan's purchase fee. - Balances: Any balances associated with the current plan will remain intact after switching to a different plan. Balances of the switched plan will be created as well.
When switching plans, it is recommended to use planId because it ensures that the subscription is automatically updated to the latest active version of the new plan going forward, minimizing the need for manual updates. However, if you need to enforce a specific version, you can use planVersionId.
Authorized Roles: Account_Admin
Response
Returns an UpdatePlanVersionSubscriptionResult!
Arguments
| Name | Description |
|---|---|
input - UpdatePlanSubscriptionInput!
|
Parameters for UpdatePlanSubscription. |
Example
Query
mutation updatePlanSubscription($input: UpdatePlanSubscriptionInput!) {
updatePlanSubscription(input: $input) {
... on SubscribeToPlanVersionPayload {
...SubscribeToPlanVersionPayloadFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on PlanVersionIsNotAssignable {
...PlanVersionIsNotAssignableFragment
}
... on AccountNotFound {
...AccountNotFoundFragment
}
... on SubscriptionNotFound {
...SubscriptionNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on SubscribeToPlanVersionValidationFailed {
...SubscribeToPlanVersionValidationFailedFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
... on PlanNotFound {
...PlanNotFoundFragment
}
... on PlanAliasNotFound {
...PlanAliasNotFoundFragment
}
... on PlanAliasNotActive {
...PlanAliasNotActiveFragment
}
}
}
Variables
{"input": UpdatePlanSubscriptionInput}
Response
{
"data": {
"updatePlanSubscription": SubscribeToPlanVersionPayload
}
}
updatePlanVersionFromInitialRecurringFirstUsageTemplate
Description
Updates a plan that was created by using a template.
Response
Returns an UpdatePlanVersionFromInitialTemplateResult!
Arguments
| Name | Description |
|---|---|
input - UpdatePlanVersionFromInitialRecurringFirstUsageTemplateInput!
|
Parameters for UpdatePlanVersionFromInitialRecurringFirstUsageTemplate. |
Example
Query
mutation updatePlanVersionFromInitialRecurringFirstUsageTemplate($input: UpdatePlanVersionFromInitialRecurringFirstUsageTemplateInput!) {
updatePlanVersionFromInitialRecurringFirstUsageTemplate(input: $input) {
... on PlanVersionPayload {
...PlanVersionPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on CreatePlanValidationFailed {
...CreatePlanValidationFailedFragment
}
... on PlanVersionIsReadOnly {
...PlanVersionIsReadOnlyFragment
}
... on PlanVersionAlreadyExists {
...PlanVersionAlreadyExistsFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on ServiceFormatError {
...ServiceFormatErrorFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on PlanVersionUpdateAlreadyInProgress {
...PlanVersionUpdateAlreadyInProgressFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"input": UpdatePlanVersionFromInitialRecurringFirstUsageTemplateInput
}
Response
{
"data": {
"updatePlanVersionFromInitialRecurringFirstUsageTemplate": PlanVersionPayload
}
}
updatePlanVersionFromInitialTemplate
Description
Updates Plan Version of a Plan that was originally created by using a template.
Authorized Roles: Plan_Designer
Response
Returns an UpdatePlanVersionFromInitialTemplateResult!
Arguments
| Name | Description |
|---|---|
input - UpdatePlanVersionFromInitialTemplateInput!
|
Parameters for UpdatePlanVersionFromInitialTemplate. |
Example
Query
mutation updatePlanVersionFromInitialTemplate($input: UpdatePlanVersionFromInitialTemplateInput!) {
updatePlanVersionFromInitialTemplate(input: $input) {
... on PlanVersionPayload {
...PlanVersionPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on PlanVersionNotFound {
...PlanVersionNotFoundFragment
}
... on BalanceTypeNotFound {
...BalanceTypeNotFoundFragment
}
... on CreatePlanValidationFailed {
...CreatePlanValidationFailedFragment
}
... on PlanVersionIsReadOnly {
...PlanVersionIsReadOnlyFragment
}
... on PlanVersionAlreadyExists {
...PlanVersionAlreadyExistsFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on ServiceFormatError {
...ServiceFormatErrorFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on PlanVersionUpdateAlreadyInProgress {
...PlanVersionUpdateAlreadyInProgressFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdatePlanVersionFromInitialTemplateInput}
Response
{
"data": {
"updatePlanVersionFromInitialTemplate": PlanVersionPayload
}
}
updateQoSProfile
Description
Updates a QoS Profile for a provider.
Authorized Roles: Plan_Designer
Response
Returns an UpdateQoSProfileResult!
Arguments
| Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
id - ID!
|
The unique identifier of the QoS profile to update. |
input - QoSProfileInput!
|
Parameters for updateQoSProfile. |
Example
Query
mutation updateQoSProfile(
$providerId: ID!,
$id: ID!,
$input: QoSProfileInput!
) {
updateQoSProfile(
providerId: $providerId,
id: $id,
input: $input
) {
... on UpdateQoSProfilePayload {
...UpdateQoSProfilePayloadFragment
}
... on QoSProfileNotFound {
...QoSProfileNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{
"providerId": 4,
"id": "4",
"input": QoSProfileInput
}
Response
{"data": {"updateQoSProfile": UpdateQoSProfilePayload}}
updateRatingGroupHierarchy
Description
Updates and deploys after verifying Rating Group hierarchy.
Authorized Roles: Network_Admin, Plan_Publisher
Response
Returns an UpdateRatingGroupHierarchyResult!
Arguments
| Name | Description |
|---|---|
input - UpdateRatingGroupHierarchyInput!
|
Parameters for UpdateRatingGroupHierarchy. |
Example
Query
mutation updateRatingGroupHierarchy($input: UpdateRatingGroupHierarchyInput!) {
updateRatingGroupHierarchy(input: $input) {
... on UpdateRatingGroupHierarchyPayload {
...UpdateRatingGroupHierarchyPayloadFragment
}
... on RatingGroupHierarchyHasReferences {
...RatingGroupHierarchyHasReferencesFragment
}
... on RatingGroupValidationFailed {
...RatingGroupValidationFailedFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateRatingGroupHierarchyInput}
Response
{
"data": {
"updateRatingGroupHierarchy": UpdateRatingGroupHierarchyPayload
}
}
updateSGSNTable
Description
Update the SGSN table for a provider.
Authorized Roles: Network_Operator, Plan_Publisher
Response
Returns an UpdateSGSNTableResult!
Arguments
| Name | Description |
|---|---|
input - UpdateSGSNTableInput!
|
Parameters for UpdateSGSNTable. |
Example
Query
mutation updateSGSNTable($input: UpdateSGSNTableInput!) {
updateSGSNTable(input: $input) {
... on UpdateSGSNTablePayload {
...UpdateSGSNTablePayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateSGSNTableInput}
Response
{"data": {"updateSGSNTable": UpdateSGSNTablePayload}}
updateSettings
Description
Updates settings of a provider.
Authorized Roles: Plan_Admin, Plan_Publisher
Response
Returns an UpdateSettingsResult!
Arguments
| Name | Description |
|---|---|
input - UpdateSettingsInput!
|
Parameters for UpdateSettings. |
Example
Query
mutation updateSettings($input: UpdateSettingsInput!) {
updateSettings(input: $input) {
... on UpdateSettingsPayload {
...UpdateSettingsPayloadFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateSettingsInput}
Response
{"data": {"updateSettings": UpdateSettingsPayload}}
updateUser
Description
Updates a specific User for a given tenant. It returns the updated user or an error.
Authorized Roles: Tenant_Admin
Response
Returns an UpdateUserResult!
Arguments
| Name | Description |
|---|---|
input - UpdateUserInput!
|
Parameters for UpdateUser |
Example
Query
mutation updateUser($input: UpdateUserInput!) {
updateUser(input: $input) {
... on SaveUserPayload {
...SaveUserPayloadFragment
}
... on UserNotFound {
...UserNotFoundFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on UserIsReadOnly {
...UserIsReadOnlyFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateUserInput}
Response
{"data": {"updateUser": SaveUserPayload}}
updateUserProfile
Description
Updates user profile for current User.
Authorized Roles: All
Response
Returns an UpdateUserProfileResult!
Arguments
| Name | Description |
|---|---|
input - UpdateUserProfileInput!
|
Parameters for UpdateUserProfile. |
Example
Query
mutation updateUserProfile($input: UpdateUserProfileInput!) {
updateUserProfile(input: $input) {
... on SaveUserPayload {
...SaveUserPayloadFragment
}
... on InvalidField {
...InvalidFieldFragment
}
... on InvalidProviderLifecycleStage {
...InvalidProviderLifecycleStageFragment
}
... on RateLimitExceeded {
...RateLimitExceededFragment
}
... on InternalServerError {
...InternalServerErrorFragment
}
}
}
Variables
{"input": UpdateUserProfileInput}
Response
{"data": {"updateUserProfile": SaveUserPayload}}
Types
AWSDate
Description
An extended ISO 8601 date string in the format YYYY-MM-DD.
Example
AWSDate
AWSDateTime
Description
An extended ISO 8601 date and time string in the format YYYY-MM-DDThh:mm:ss.sssZ.
Example
AWSDateTime
AWSEmail
Description
An email address in the format local-part@domain-part as defined by RFC 822.
Example
AWSEmail
AWSJSON
Description
A JSON string. Any valid JSON construct is automatically parsed and loaded in the resolver mapping templates as maps, lists, or scalar values rather than as the literal input strings. Unquoted strings or otherwise invalid JSON result in a GraphQL validation error.
Example
AWSJSON
AWSPhone
Description
A phone number. This value is stored as a string. Phone numbers can contain either spaces or hyphens to separate digit groups. Phone numbers without a country code are assumed to be US/North American numbers adhering to the North American Numbering Package (NANP).
Example
AWSPhone
AWSURL
Description
A URL as defined by RFC 1738. For example, https://www.amazon.com/dp/B000NZW3KC/ or mailto:example@example.com. URLs must contain a schema (http, mailto) and can't contain two forward slashes (//) in the path part.
Example
AWSURL
Account
Description
An account to manage multiple devices.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of an account. |
customData - AWSJSON
|
Any custom data required by the account. Can include used and reserved balance for different services. |
parent - Account
|
The parent account in an account hierarchy. |
inactivePlanVersions - [SubscribedPlanVersion]
|
Any plan version that the account is subscribed to but is not currently active. Newly subscribed to plans are inactive until the first credit/charge request. |
activePlanVersions - [SubscribedPlanVersion]
|
Any plan version that the account is subscribed to and are currently active. The same plan service can not be used in multiple version. |
archivedPlanVersions - [SubscribedPlanVersion]
|
Any plan version that the account was subscribed to but the subscription ended. |
friendsAndFamily - [String]
|
List of friends and family. This field is deprecated in favor of custom fields. Deprecated date is 2025-02-14. Expiration date is 2025-04-13. |
creditLimit - Float
|
The limit an account can be credited to. It should be negative/zero for prepaid accounts and positive for postpaid accounts. |
notificationCreditLimitThresholds - [Float]
|
Thresholds of the default monetary balance on the account. Whenever the account balance goes lower than any of the values in the set a notification is sent. |
balances - [AccountBalanceInfo!]!
|
Balances associated with the Account, either created through plan subscriptions and renewals or manually added via the createBalance API. |
postpaid - AccountPostpaidProperties
|
If account is a postpaid account, i.e. creditLimit is greater than zero, this holds the postpaid properties |
churnScore - Float
|
The churn score for the account, which is the probability that this account would churn |
activatedAt - AWSDateTime
|
Date of account activation. |
accountLifecycle - AccountLifecycle
|
Information about the Account’s assigned Lifecycle |
Example
{
"providerId": 4,
"id": "4",
"customData": AWSJSON,
"parent": Account,
"inactivePlanVersions": [SubscribedPlanVersion],
"activePlanVersions": [SubscribedPlanVersion],
"archivedPlanVersions": [SubscribedPlanVersion],
"friendsAndFamily": ["xyz789"],
"creditLimit": 123.45,
"notificationCreditLimitThresholds": [123.45],
"balances": [AccountBalanceInfo],
"postpaid": AccountPostpaidProperties,
"churnScore": 123.45,
"activatedAt": AWSDateTime,
"accountLifecycle": AccountLifecycle
}
AccountAlreadyExists
Description
An error type to be thrown if an account with provided ID already exists.
Example
{
"accountId": "4",
"errorCode": "abc123",
"errorMessage": "xyz789"
}
AccountBalanceInfo
Description
Balance details return type.
Fields
| Field Name | Description |
|---|---|
balanceId - ID!
|
ID for the balance. |
balanceType - BalanceTypePayload!
|
Each balance is associated with a BalanceType, which defines its characteristics, such as type (e.g., volume, time, rate), notification thresholds, policy counters, and the maximum allowable value. |
priority - Float!
|
Priority of the balance. If there are multiple balances of the same type, the one with the highest priority will be used first. |
unlimited - Boolean
|
Whether the balance is unlimited or not. |
limit - Float
|
The maximum amount a balance can reach through credit operations. For multiple balances of the same Rate-based balances (e.g., the default Monetary balance) can have decimal limits, while others (e.g., volume, time) should use integers. |
from - AWSDateTime
|
Defines the start date of the balance's validity.
|
to - AWSDateTime
|
Defines the end date of the balance's validity.
|
total - Float
|
The allowance of the balance configured in the plan service managing that balance. Total is the sum of Available, Reserved and Used. Modifications to the balance through the updateBalance API directly affect the Total value; credits increase Total and debits decrease Total. |
reserved - Float
|
The quantity of money or service (bytes, seconds, units) reserved by active sessions. |
used - Float
|
The quantity of money or service consumed during the balance’s lifetime where lifetime is defined as the period between the balance 'from' and 'to' dates. The only exception is the default monetary balance on postpaid accounts, which resets monthly on the Billing Day of Month. |
available - Float
|
The quantity of money or service available for consumption, excluding active reservations. At renewal, if rollover is configured, the available balance is also adjusted according to rollover settings (e.g., maximum rollover amount per period). |
value - Float
|
The quantity of money or service, including active reservations. The calculation is total - used. |
counters - [BalanceTypeCounterPayload!]
|
All counters configured on the balance, including notification counters for allowance thresholds and policy counters to enable PCRF/PCF interworking. By default, counters are inherited from the BalanceType of the balance and can be overridden at the account level using |
planSubscriptionId - ID
|
The ID of the associated plan subscription if the balance is managed by a plan service. |
Example
{
"balanceId": "4",
"balanceType": BalanceTypePayload,
"priority": 123.45,
"unlimited": false,
"limit": 123.45,
"from": AWSDateTime,
"to": AWSDateTime,
"total": 123.45,
"reserved": 123.45,
"used": 987.65,
"available": 987.65,
"value": 987.65,
"counters": [BalanceTypeCounterPayload],
"planSubscriptionId": "4"
}
AccountBalanceTypeCounterNotFound
Description
An error type to be thrown if the Balance Type Counter was not found with the given inputs for the account.
Example
{
"balanceTypeCounterId": 4,
"balanceTypeId": "4",
"accountId": "4",
"errorCode": "abc123",
"errorMessage": "abc123"
}
AccountBalanceTypeCounterPayload
Description
A representation of a single Balance Type Counter overridden in an Account.
Fields
| Field Name | Description |
|---|---|
balanceTypeId - ID!
|
The Balance Type associated with the Balance Type Counter. |
accountId - ID!
|
The account ID associated with the Balance Type Counter. |
counter - BalanceTypeCounterPayload!
|
The counter information payload. |
Example
{
"balanceTypeId": 4,
"accountId": 4,
"counter": BalanceTypeCounterPayload
}
AccountBalanceTypeCounterResult
Description
Return type of BalanceTypeCounter including all possible errors.
AccountNotFound (AccountNotFound)- The specified account does not exist.AccountBalanceTypeCounterNotFound (AccountBalanceTypeCounterNotFound)- The specified counter does not exist in the account.BalanceTypeNotFound (BalanceTypeNotFound)- The specified balance type does not exist.
Example
AccountBalanceTypeCounterPayload
AccountBalanceTypeCountersPayload
Description
A representation of BalanceType counters configured on an account.
A BalanceType counter is created on the account the first time a balance of a certain BalanceType is created, either during plan subscription or through the createBalance API. The corresponding counter configuration is inherited from the BalanceType.
Once the counter configuration is copied to the account, any modifications can only be made using the updateAccountBalanceTypeCounter API. Changes made to the BalanceType counters after it is copied to the account are not reflected to the account Balance Type Counters.
Fields
| Field Name | Description |
|---|---|
balanceTypeId - ID!
|
The Balance Type associated with the counter. |
accountId - ID!
|
The account ID associated with the Balance Type Counter. |
counters - [BalanceTypeCounterPayload!]!
|
List of counter payload on the account configured for the given BalanceType. |
Example
{
"balanceTypeId": "4",
"accountId": 4,
"counters": [BalanceTypeCounterPayload]
}
AccountBalanceTypeCountersResult
Description
Return type of several BalanceTypeCounter items including all possible errors.
AccountNotFound (AccountNotFound)- The specified account does not exist.AccountBalanceTypeCounterNotFound (AccountBalanceTypeCounterNotFound)- The specified counter does not exist in the account.BalanceTypeNotFound (BalanceTypeNotFound)- The specified balance type does not exist.
Example
AccountNotFound
AccountHasReferences
Description
An error type to be thrown if an account has references preventing it from deletion.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
An account for a provided provider ID has references (such as devices or children accounts) preventing it from deletion. |
accountId - ID!
|
An account with a provided account ID has references (such as devices or children accounts) preventing it from deletion. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"providerId": "4",
"accountId": 4,
"errorCode": "abc123",
"errorMessage": "xyz789"
}
AccountLifecycle
Description
Information about the Account’s assigned Lifecycle.
Fields
| Field Name | Description |
|---|---|
lifecycle - Lifecycle!
|
Assigned Lifecycle. |
state - String!
|
Current state within the assigned Lifecycle. |
transitionTime - AWSDateTime!
|
Time of transition to the current state. |
expiryDays - Int
|
Number of days after transitionTime before transitioning to the next state. Either the default value from the lifecycle or the value set when transitioning. Null indicates no expiry time. |
expiryDate - AWSDateTime
|
The calculated expiry date for the current state. |
Example
{
"lifecycle": Lifecycle,
"state": "xyz789",
"transitionTime": AWSDateTime,
"expiryDays": 123,
"expiryDate": AWSDateTime
}
AccountLifecycleInput
Description
Information about the Account’s assigned Lifecycle
Example
{
"lifecycle": 4,
"state": "xyz789",
"expiryDays": 987
}
AccountNotFound
Description
An error type to be thrown if an account was not found.
Example
{
"providerId": 4,
"accountId": 4,
"errorCode": "abc123",
"errorMessage": "abc123"
}
AccountPostpaidProperties
Description
Type to hold the postpaid properties of accounts
Fields
| Field Name | Description |
|---|---|
timezone - String
|
The timezone of the user in +/-hh:mm or Country/City format. This is a property for postpaid accounts only. This is a property for postpaid accounts only. |
billingDayOfMonth - Int
|
The day of month for resetting balance and units for account. Value is between 1 and 31 inclusive. This is a property for postpaid accounts only. |
newBillingDayOfMonth - Int
|
The new day of month for resetting balance and units for account. Value is between 1 and 31 inclusive. This is a property for postpaid accounts only. |
lastBillingDate - AWSDate
|
The date (in yyyy-mm-dd format) of the previous billing. This is a property for postpaid accounts only. |
longFirstBillingCycle - Boolean
|
Whether the first billing cycle is a long one, e.g. if billing DoM is on the 1st and the account was created on the 16th. If this value is true, it means that the first bill will be for 45 days, while if false, bill will be for 15 days only. This is a property for postpaid accounts only. |
newLongFirstBillingCycle - Boolean
|
Whether the new first billing cycle is a long one, e.g. if billing DoM is on the 1st and the account was created on the 16th. If this value is true, it means that the first bill will be for 45 days, while if false, bill will be for 15 days only. This is a property for postpaid accounts only. |
Example
{
"timezone": "xyz789",
"billingDayOfMonth": 123,
"newBillingDayOfMonth": 987,
"lastBillingDate": AWSDate,
"longFirstBillingCycle": false,
"newLongFirstBillingCycle": true
}
AccountResult
Description
Return type of Account including all possible errors.
Types
| Union Types |
|---|
Example
Account
AdjustmentType
Description
Balance adjustment type.
Values
| Enum Value | Description |
|---|---|
|
|
If amount need to be added to the balance. |
|
|
If amount need to be subtracted from the balance. |
|
|
If amount need to be set as the balance. |
|
|
If no balance adjustment. |
Example
"CREDIT"
Alias
Fields
| Field Name | Description |
|---|---|
planVersionId - ID!
|
The plan version ID that is being aliased. |
effectiveTime - AWSDateTime
|
The effective time the plan version ID becomes active for the alias. |
migrationType - MigrationType!
|
The migration type of the alias. |
Example
{
"planVersionId": 4,
"effectiveTime": AWSDateTime,
"migrationType": "TIME"
}
AliasInput
Fields
| Input Field | Description |
|---|---|
effectiveTime - AWSDateTime
|
The optional time the new plan version should become active in the alias. Needs to be at least 6min in the future. If not provided and 'migrationFromVersions' is not provided as well, the alias will be active in 6min in the future. |
migrationType - MigrationType
|
The optional migration type how the new plan version should become active. The default is TIME if not passed. |
Example
{"effectiveTime": AWSDateTime, "migrationType": "TIME"}
Ambr
AmbrInput
Description
Input for Aggregate Maximum Bit Rate parameters.
Example
{
"maxBitRateDL": "xyz789",
"maxBitRateUL": "abc123"
}
AnnouncementMapping
Description
Type for mapping specific conditions to announcement codes.
Fields
| Field Name | Description |
|---|---|
endUserServiceDenied - Float
|
Announcement code to return when end user service is denied. Providing a negative value will explicitly delete it. |
quotaLimitReached - Float
|
Announcement code to return when quota limit is reached. Providing a negative value will explicitly delete it. |
otherError - Float
|
Announcement code to return for other error conditions. Providing a negative value will explicitly delete it. |
Example
{
"endUserServiceDenied": 123.45,
"quotaLimitReached": 123.45,
"otherError": 987.65
}
AnnouncementMappingInput
Description
Input type for mapping specific conditions to announcement codes.
Fields
| Input Field | Description |
|---|---|
endUserServiceDenied - Float
|
Announcement code to return when end user service is denied. Providing a negative value will explicitly delete it. |
quotaLimitReached - Float
|
Announcement code to return when quota limit is reached. Providing a negative value will explicitly delete it. |
otherError - Float
|
Announcement code to return for other error conditions. Providing a negative value will explicitly delete it. |
Example
{
"endUserServiceDenied": 987.65,
"quotaLimitReached": 123.45,
"otherError": 987.65
}
ApiLimitsConfig
Description
The configurations for limiting a specific API. currentRate and averageRate may show high values as the cold start is at max.
Fields
| Field Name | Description |
|---|---|
apiType - ApiType!
|
API type including 4G/5G interface. |
rejectRequestsOverSoftLimit - Boolean
|
If true, API requests are rejected beyond the soft limit. Use minLimit, maxLimit, burstPercentage, currentLimit, currentRate, and averageRate for the Rate Limiting Standalone component instead. |
softLimitTps - Int
|
The soft limit for the average number of transactions per second. Use minLimit, maxLimit, burstPercentage, currentLimit, currentRate, and averageRate for the Rate Limiting Standalone component instead. |
hardLimitTps - Int
|
The hard limit for the average number of transactions per second. Use minLimit, maxLimit, burstPercentage, currentLimit, currentRate, and averageRate for the Rate Limiting Standalone component instead. |
overSoftLimitUntil - AWSDateTime
|
DateTime when the provider will no longer be over the soft limit. Use minLimit, maxLimit, burstPercentage, currentLimit, currentRate, and averageRate instead. |
overHardLimitUntil - AWSDateTime
|
DateTime when the provider will no longer be over the hard limit. Use minLimit, maxLimit, burstPercentage, currentLimit, currentRate, and averageRate instead. |
minLimit - Int!
|
Rate limit, in requests per second, allowed regardless of current average rate. |
maxLimit - Int!
|
Absolute maximum rate limit, in requests per second. |
burstPercentage - Int!
|
Percentage allowed to burst above average rate limit. |
currentLimit - Int!
|
Current limit being applied to requests; will be between minLimit and maxLimit. |
currentRate - Int!
|
Number of requests allowed in the last second. |
averageRate - Float!
|
Average number of requests per second over the last 5 minutes. |
Example
{
"apiType": "DA_GY",
"rejectRequestsOverSoftLimit": false,
"softLimitTps": 987,
"hardLimitTps": 123,
"overSoftLimitUntil": AWSDateTime,
"overHardLimitUntil": AWSDateTime,
"minLimit": 123,
"maxLimit": 123,
"burstPercentage": 123,
"currentLimit": 987,
"currentRate": 987,
"averageRate": 123.45
}
ApiType
Description
All possible API types including 4G/5G interface.
Values
| Enum Value | Description |
|---|---|
|
|
Diameter Adapter (4G) Gy interface. |
|
|
Diameter Adapter (4G) Sy interface. |
|
|
Engine (5G) n7 interface. |
|
|
Engine (5G) n40 interface. |
|
|
Engine (5G) n28 interface. |
|
|
AppSync (GraphQL) API. |
Example
"DA_GY"
ArchivePlanVersionInput
ArchivePlanVersionPayload
Description
Return type of ArchivePlanVersion.
Fields
| Field Name | Description |
|---|---|
archivedPlanVersion - PlanVersionInterface!
|
A plan version that has been archived. |
Example
{"archivedPlanVersion": PlanVersionInterface}
ArchivePlanVersionResult
Description
Return type of ArchivePlanVersion including all possible errors.
Example
ArchivePlanVersionPayload
AssignablePlanVersionInput
Description
Input type of MakePlanVersionAssignable and MakePlanVersionNotAssignable.
Example
{"providerId": 4, "planVersionId": "4"}
AssignablePlanVersionResult
Description
Return type of MakePlanVersionAssignable and MakePlanVersionNotAssignable including all possible errors.
PlanVersionNotFound (PlanVersionNotFound)- The requested plan version with the provided ID cannot be found.MigrationAlreadyInProgress (MigrationAlreadyInProgress)- Another migration on the same plan can be done only when the current migration is finished.PlanVersionWrongTransition (PlanVersionIsAlreadyInState)- The plan version is already in the correct state. Transition is not required.PlanVersionWrongTransition (PlanVersionIsAlreadyInState)- The plan version is already archived and can not move to suspended anymore.PlanVersionWrongTransition (PlanVersionCanNotBeAvailable)- The state of a plan version can be changed to available only if it is in suspended or deployed state.PlanVersionWrongTransition (PlanVersionCanNotBeSuspended)- The state of a plan version can be changed to suspended only if it is in available or deployed state.PlanVersionWrongTransition (PlanAliasUsesVersions)- The plan version is part of a plan alias and other versions of the plan alias that would be made unassignable are either in use or will be in use by the alias.InternalServerError (ChargeEngineNotAvailable)- The charge engine is not available at this time.
Example
PlanVersionPayload
AuthProvider
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
Example
"apiKey"
AuthRule
Fields
| Input Field | Description |
|---|---|
allow - AuthStrategy!
|
|
provider - AuthProvider
|
|
ownerField - String
|
|
identityClaim - String
|
|
groupClaim - String
|
|
groups - [String]
|
|
groupsField - String
|
|
operations - [ModelOperation]
|
|
queries - [ModelQuery]
|
|
mutations - [ModelMutation]
|
Example
{
"allow": "owner",
"provider": "apiKey",
"ownerField": "xyz789",
"identityClaim": "abc123",
"groupClaim": "xyz789",
"groups": ["abc123"],
"groupsField": "abc123",
"operations": ["create"],
"queries": ["get"],
"mutations": ["create"]
}
AuthStrategy
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
Example
"owner"
BalanceHasReferences
Description
An error type to be thrown if the balance is used in an active account.
Example
{
"balanceId": 4,
"errorCode": "abc123",
"errorMessage": "xyz789"
}
BalanceNotFound
Description
An error type to be thrown if a balance was not found.
Example
{
"providerId": "4",
"balanceId": 4,
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
BalancePayload
Description
Balance return type.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Provider ID. |
accountId - ID!
|
Account ID. |
balanceInfo - AccountBalanceInfo!
|
Details of the created balance, including its type, value, and validity. |
transactionId - ID!
|
The transaction ID returned as a result of the If not provided in the request, Totogi generates a unique identifier for the transaction. |
Example
{
"providerId": 4,
"accountId": 4,
"balanceInfo": AccountBalanceInfo,
"transactionId": "4"
}
BalanceTypeCounterInput
Description
Input parameters for updating Balance Type Counter configuration.
Fields
| Input Field | Description |
|---|---|
balanceTypeCounterId - ID
|
The unique identifier for the Balance Type Counter. If balanceTypeCounterId is not provided, a new counter will be created. Otherwise, the existing counter will be modified. |
name - String
|
The unique name associated with the Balance Type Counter. This name will appear in the Event Bridge notifications. If the counter is used to track policy management, the name should be set to the PCRF policy counter name, while individual state names should match the PCRF counter value in the The name is required if |
period - BalanceTypeCounterPeriodInput
|
The optional reset date for the Balance Type Counter. Note: This feature is reserved for future implementation and is currently not functional. |
isActive - Boolean
|
Indicates whether the counter is active or not. |
states - [BalanceTypeCounterStateInput]
|
An optional list of states associated with the Balance Type Counter. The current state of a counter is determined by comparing the threshold value against the balance values, either the used balance (if isOnUsedBalance is true) or the available balance (if isOnUsedBalance is false). The isExclusive parameter determines whether reservations are included on top of available or used when calculating the current state. |
isExclusive - Boolean
|
Indicates whether the counter includes or excludes reservations when calculating the current state.
|
isOnUsedBalance - Boolean
|
Indicates whether the counter operates on the remaining (available) balance or the used balance. |
Example
{
"balanceTypeCounterId": 4,
"name": "abc123",
"period": BalanceTypeCounterPeriodInput,
"isActive": false,
"states": [BalanceTypeCounterStateInput],
"isExclusive": true,
"isOnUsedBalance": true
}
BalanceTypeCounterNotFound
Description
An error type to be thrown if Balance Type Counter was not found with the given inputs.
Example
{
"balanceTypeCounterId": 4,
"balanceTypeId": "4",
"errorCode": "abc123",
"errorMessage": "xyz789"
}
BalanceTypeCounterPayload
Description
A representation of Balance Type Counter.
Fields
| Field Name | Description |
|---|---|
balanceTypeCounterId - ID!
|
The unique identifier for the Balance Type Counter. |
name - String!
|
The unique name associated with the Balance Type Counter. This name will appear in the Event Bridge notifications. If the counter is used to track policy management, the name should be the PCRF policy counter name, while individual state names should match the PCRF counter value in the states array. |
period - BalanceTypeCounterPeriod
|
The optional reset date for the Balance Type Counter. Note: This feature is reserved for future implementation and is currently not functional. |
isActive - Boolean
|
Indicates whether the counter is active or not. |
states - [BalanceTypeCounterState]
|
An optional list of states associated with the Balance Type Counter. The current state of a counter is determined by comparing the threshold value against the balance values, either the used balance (if The |
isExclusive - Boolean!
|
Indicates whether the counter includes or excludes reservations when calculating the current state.
|
isOnUsedBalance - Boolean!
|
Indicates whether the counter operates on the remaining (available) balance or the used balance. |
Example
{
"balanceTypeCounterId": "4",
"name": "abc123",
"period": BalanceTypeCounterPeriod,
"isActive": true,
"states": [BalanceTypeCounterState],
"isExclusive": false,
"isOnUsedBalance": true
}
BalanceTypeCounterPeriod
Description
Information when balance counter value resets.
Important: This feature is reserved for future implementation and is currently not functional.
Fields
| Field Name | Description |
|---|---|
type - CounterPeriodType!
|
The period when counter value must be reset. |
hourOfDay - Int
|
The hour at which a balance type counter is reset in UTC in case of DAILY periods. |
dayOfMonth - Int
|
The day on which a balance type counter is reset in case of MONTHLY periods. |
Example
{"type": "SAME_AS_PLAN", "hourOfDay": 987, "dayOfMonth": 123}
BalanceTypeCounterPeriodInput
Description
Information when balance counter value must be reset.
Important: This feature is reserved for future implementation and is currently not functional.
Fields
| Input Field | Description |
|---|---|
type - CounterPeriodType!
|
Determines the period when the counter value must be reset. Use the option NONE when providing the counter period. |
hourOfDay - Int
|
The hour at which a balance type counter is reset in UTC. Applicable for DAILY periods. Has to be in range of 0 - 23. Default is 0. |
dayOfMonth - Int
|
The day on which a balance type counter is reset. Required for MONTHLY periods. Has to be in range of 1 - 31. If the day is not valid for the month, the reset will happen on the last day of the month. |
Example
{"type": "SAME_AS_PLAN", "hourOfDay": 123, "dayOfMonth": 123}
BalanceTypeCounterResult
Description
Return type of BalanceTypeCounter including all possible errors.
BalanceTypeCounterNotFound (BalanceTypeCounterNotFound)- The balance type ID provided does not exist.BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.
Example
UpdateBalanceTypeCounterPayload
BalanceTypeCounterState
Description
Defines the name, threshold, and action for a Balance Type Counter state.
A state represents a specific threshold in the counter’s operation and triggers the configured actions when that threshold is reached. Each counter has at least one initial state with a null threshold.
Fields
| Field Name | Description |
|---|---|
name - String!
|
The unique name of the Balance Type Counter's current state. This name is used to identify both the previous and current states in Event Bridge notifications. If the counter is configured for policy management, state names should correspond to the PCRF policy counter values of the associated policy counter. The name must be between 1 and 50 characters and consist of letters, digits, or special characters. |
threshold - Float
|
The threshold value that determines when the Balance Type Counter transitions to the specified state. If no threshold is provided, the state is considered the default state. This threshold is compared against either the used or available balance to trigger state transitions.
|
actions - [BalanceTypeCounterStateAction!]!
|
Actions to perform when the state is triggered. |
Example
{
"name": "abc123",
"threshold": 987.65,
"actions": ["NOTIFY"]
}
BalanceTypeCounterStateAction
Description
The action to perform when a Balance Type Counter State is triggered.
Values
| Enum Value | Description |
|---|---|
|
|
Trigger notification when the state is triggered. |
|
|
Block the balance (if not blocked) when this state is triggered. |
|
|
Unblock the balance (if blocked) when this state is triggered. |
Example
"NOTIFY"
BalanceTypeCounterStateInput
Description
Defines the name, threshold, and action for a Balance Type Counter state. A state represents a specific threshold in the counter’s operation and triggers the configured actions when that threshold is reached. Each counter must have at least one initial state with a null threshold. If not provided, the backend automatically creates an initial state with name: "normal", threshold: null, and action: "notify".
Fields
| Input Field | Description |
|---|---|
name - String!
|
The unique name of the Balance Type Counter's current state. This name is used to identify both the previous and current states in Event Bridge notifications. If the counter is configured for policy management, state names should correspond to the PCRF values of the associated policy counter. The name must be between 1 and 50 characters and consist of letters, digits, or special characters. |
threshold - Float
|
The threshold value that determines when the Balance Type Counter transitions to the specified state. If no threshold is provided, the state is considered the default state. This threshold is compared against either the used or available balance to trigger state transitions.
|
actions - [BalanceTypeCounterStateAction!]
|
Specifies the actions to be performed when the counter reaches the given state.
Actions typically include notifications sent to Event Bridge. If the counter is configured for Policy Management, the PCRF is additionally notified about state changes for the subscribed counters. |
Example
{
"name": "abc123",
"threshold": 123.45,
"actions": ["NOTIFY"]
}
BalanceTypeCountersPayload
Description
A representation of Balance Type Counters associated with a balance type.
Fields
| Field Name | Description |
|---|---|
balanceTypeId - ID!
|
The Balance Type associated with the Balance Type Counter. |
counters - [BalanceTypeCounterPayload]!
|
The counters information payload. |
Example
{
"balanceTypeId": "4",
"counters": [BalanceTypeCounterPayload]
}
BalanceTypeHasReferences
Description
An error type to be thrown if the balance type is used in an active plan.
Example
{
"balanceTypeId": "4",
"errorCode": "xyz789",
"errorMessage": "abc123"
}
BalanceTypeNameInUse
Description
An error type to be thrown if the BalanceType name is already in use.
Example
{
"balanceTypeId": 4,
"name": "xyz789",
"errorCode": "xyz789",
"errorMessage": "abc123"
}
BalanceTypeNotFound
Description
An error type to be thrown if a balance type was not found.
Example
{
"providerId": "4",
"balanceTypeId": 4,
"errorCode": "xyz789",
"errorMessage": "abc123"
}
BalanceTypePayload
Description
Balance type return type.
Fields
| Field Name | Description |
|---|---|
balanceTypeId - ID!
|
ID for the balance type. |
providerId - ID!
|
Provider ID. |
name - String!
|
Name of the balance type. |
unitType - UnitType!
|
Unit type of the balance type. |
limit - Float
|
The maximum amount a balance of a specific Rate-based balances (e.g., the default Monetary balance) can have decimal limits, while others (e.g., volume, time) should use integers. |
rateBased - Boolean!
|
Specifies whether the BalanceType is rate-based, like the default Monetary balance, or allowance-based, measured in units (e.g., time, volume). |
counters - [BalanceTypeCounterPayload!]
|
List of counters configured for the given BalanceType. |
Example
{
"balanceTypeId": "4",
"providerId": 4,
"name": "xyz789",
"unitType": "TIME",
"limit": 123.45,
"rateBased": false,
"counters": [BalanceTypeCounterPayload]
}
Boolean
Description
The Boolean scalar type represents true or false.
CancelPlanSubscriptionInput
Description
Input type of CancelPlanSubscription.
Example
{
"planSubscriptionId": 4,
"providerId": "4",
"accountId": 4
}
CancelPlanVersionSubscriptionPayload
CancelPlanVersionSubscriptionResult
Description
Return type of CancelPlanVersionSubscription including all possible errors.
AccountNotFound (AccountNotFound)- The requested account with the provided ID cannot be found.SubscriptionNotFound (SubscriptionNotFound)- The plan subscription with the provided ID was not found.InternalServerError (ChargeEngineNotAvailable)- The charge engine is not available at this time.
Example
CancelPlanVersionSubscriptionPayload
CannotChangeAccountType
Description
An error that is thrown when user tries to change a postpaid account into a prepaid one and vice versa
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Account for a provided provider ID cannot be changed from postpaid to prepaid and vice versa. |
accountId - ID!
|
Account with a provided account ID cannot be changed from postpaid to prepaid and vice versa. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"providerId": "4",
"accountId": "4",
"errorCode": "xyz789",
"errorMessage": "abc123"
}
CannotSetLongFirstBillingCycle
Description
An error that is thrown when user tries to set longFirstBillingCycle without changing DoM
Example
{
"providerId": 4,
"accountId": "4",
"errorCode": "xyz789",
"errorMessage": "abc123"
}
ClientCreationLimitExceeded
Description
An error type to be thrown if the client creation limit exceeds the maximum allowed (10).
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
The provider ID for the service or system attempting to create the client credentials. |
currentClientCount - Int!
|
The current number of client credentials in the system. |
maxClientLimit - Int!
|
The maximum allowed number of client credentials (set to 10). |
errorCode - String!
|
The error code associated with the failure. |
errorMessage - String
|
A detailed error message explaining the failure. |
Example
{
"providerId": "4",
"currentClientCount": 123,
"maxClientLimit": 987,
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
ClientCredentials
Fields
| Field Name | Description |
|---|---|
clientId - ID!
|
Unique identifier for the client credentials. |
providerId - ID!
|
The ID of the provider to which this credentials belongs. |
name - String!
|
The descriptive name of the client credentials. |
email - AWSEmail!
|
The email of the user associated with the client credentials. |
roleGroupMemberships - [RoleGroup!]!
|
The roles assigned to this client credentials. |
Example
{
"clientId": "4",
"providerId": "4",
"name": "xyz789",
"email": AWSEmail,
"roleGroupMemberships": ["Account_Query"]
}
ClientNotFound
Description
An error type to be thrown if client was not found with the given inputs.
Example
{
"providerId": "4",
"clientId": 4,
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
Counter
Description
Counters provide a posibility to calculate spending values and change their states based on the calculations. Later on their state can be used to provide notifications to the customer. They enable other elements of the Provider's core network to support real-time quality-of-service and other policies, even for post-paid offline transactions.
Fields
| Field Name | Description |
|---|---|
name - String!
|
Unique name for this Counter. |
persistent - Boolean!
|
Persistent counter saves its state between sessions, transient counter resets its state between sessions. |
period - CounterPeriod
|
Determines when a counter is reset. |
selector - String
|
Boolean expression to determine if the current event should be counted. |
increment - String!
|
Value expression that will be used to increment the counter. |
states - [CounterState!]!
|
Possible states of the counter. |
notificationFields - [String]
|
Additional notification fields which are sent in notifications caused by this counter. |
Example
{
"name": "xyz789",
"persistent": true,
"period": CounterPeriod,
"selector": "xyz789",
"increment": "abc123",
"states": [CounterState],
"notificationFields": ["abc123"]
}
CounterPeriod
Description
Information when counter value must be reset.
Fields
| Field Name | Description |
|---|---|
type - CounterPeriodType!
|
Determines a period when counter value must be reset. |
data - String!
|
Value expression, specific for the given period type - e.g. the hour to reset daily counter. |
Example
{"type": "SAME_AS_PLAN", "data": "xyz789"}
CounterPeriodType
Description
Possible period types for counters.
Values
| Enum Value | Description |
|---|---|
|
|
Counter value is reset when the plan that contains the counter is renewed. |
|
|
Counter value is reset every month. |
|
|
Counter value is reset every day. |
|
|
Counter value is never reset. |
Example
"SAME_AS_PLAN"
CounterState
Description
List of name / value pairs used to determine the counter's current state.
Example
{
"name": "abc123",
"threshold": "xyz789"
}
CreateAccountInput
Description
Input type of CreateAccount.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
accountId - ID
|
A unique identifier of an account. |
parentAccountId - ID
|
The parent account in an account hierarchy. |
customData - AWSJSON
|
Any custom data required by the account. |
friendsAndFamily - [String]
|
List of friends and family. This field is deprecated in favor of custom fields. Deprecated date is 2025-02-14. Expiration date is 2025-04-13. |
creditLimit - Float
|
The limit an account can be credited to. It should be negative/zero for prepaid accounts and positive for postpaid accounts. |
notificationCreditLimitThresholds - [Float!]
|
Thresholds of the default monetary balance on the account. Whenever the account balance goes lower than any of the values in the set a notification is sent. |
balances - [CreateBalanceInfoInput!]
|
Balances types for account. TODO: Make it required field when moving to schema.graphql |
postpaid - CreateAccountPostpaidPropertiesInput
|
If account is a postpaid account, i.e. creditLimit is greater than zero, this holds the postpaid properties |
activatedAt - AWSDateTime
|
Date of account activation. If it is set, then it’s used, else, it defaults to the invocation time of the mutation. |
transactionId - ID
|
An optional transaction ID to ensure idempotency of the API call if required. |
accountLifecycle - AccountLifecycleInput
|
Initial Lifecycle and state to assign to the new account |
Example
{
"providerId": "4",
"accountId": 4,
"parentAccountId": 4,
"customData": AWSJSON,
"friendsAndFamily": ["xyz789"],
"creditLimit": 987.65,
"notificationCreditLimitThresholds": [987.65],
"balances": [CreateBalanceInfoInput],
"postpaid": CreateAccountPostpaidPropertiesInput,
"activatedAt": AWSDateTime,
"transactionId": 4,
"accountLifecycle": AccountLifecycleInput
}
CreateAccountPayload
CreateAccountPostpaidPropertiesInput
Description
An input type to hold the postpaid properties of accounts to enforce required fields for postpaid accounts only
Fields
| Input Field | Description |
|---|---|
timezone - String!
|
The timezone of the user in +/-hh:mm or Country/City format. This is a property for postpaid accounts only. |
billingDayOfMonth - Int!
|
The day of month for resetting balance and units for account. Value is between 1 and 31 inclusive. This is a property for postpaid accounts only. |
longFirstBillingCycle - Boolean!
|
Whether the first billing cycle is a long one, e.g. if billing DoM is on the 1st and the account was created on the 16th. If this value is true, it means that the first bill will be for 45 days, while if false, bill will be for 15 days only. This is a property for postpaid accounts only. |
Example
{
"timezone": "xyz789",
"billingDayOfMonth": 123,
"longFirstBillingCycle": true
}
CreateAccountResult
Description
Return type of CreateAccount including all possible errors.
BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.LifecycleNotFound (LifecycleNotFound)- The specified lifecycle doesn't exist.TransactionHasBeenProcessed (TransactionHasBeenProcessed)- The transaction has been processed.InvalidField (InvalidLifecycleState)- The state for the lifecycle is invalid.InvalidField (InvalidFriendsAndFamilyList)- Friends and family list can consist of 20 numbers maximum.InvalidField (InvalidFriendsAndFamilyNumber)- Friends and family list consists of invalid number. The only allowed format is E.164.InvalidField (InvalidJsonCreditLimit)- Cannot set credit limit from json.creditLimit. Must use creditLimit directly.InvalidField (InvalidJsonCustomData)- The provided customData is an invalid JSON.InvalidField (InvalidTimezone)- Timezone format is wrong. It should be between -12:00 and +14:00 or use a Country/City format.InvalidField (InvalidDayOfMonth)- Billing day of month should be between 1 and 31 inclusive.InvalidField (InvalidCreateBalanceInfoInput)- Only value field can be provided for the default monetary balance type.InvalidField (BalanceLimitViolation)- When the balance total exceeds the balance or balance type limit or limit exceeds the limit in balance type.
Example
CreateAccountPayload
CreateBalanceInfoInput
Description
Input type for creating a new balance details.
Fields
| Input Field | Description |
|---|---|
balanceTypeId - ID!
|
ID of the BalanceType, which defines the characteristics of the balance to be created, such as type (e.g., volume, time, rate), notification thresholds, policy counters, and the maximum allowable value. |
priority - Float!
|
Priority of the balance. If there are multiple balances of the same type, the one with the highest priority will be used first. |
value - Float!
|
Value of the balance. |
limit - Float
|
The maximum amount a balance can reach through credit operations. If there are multiple balances of the same BalanceType on the account, the limit applies independently to each balance. If not specified, limits are inherited from the BalanceType. For rate-based |
from - AWSDateTime
|
Defines the start date of the balance's validity. |
to - AWSDateTime
|
Defines the end date of the balance's validity. |
Example
{
"balanceTypeId": 4,
"priority": 123.45,
"value": 987.65,
"limit": 987.65,
"from": AWSDateTime,
"to": AWSDateTime
}
CreateBalanceInput
Description
Input type for creating a new balance.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Provider ID. |
accountId - ID!
|
Account ID. |
balanceInfo - CreateBalanceInfoInput!
|
Details of the balance to be created, including its type, value, and validity. |
transactionId - ID
|
An optional transaction ID to ensure idempotency of the API call, allowing for transaction correlation between Totogi and upstream systems. If not provided, Totogi automatically generates a unique identifier for each transaction |
Example
{
"providerId": 4,
"accountId": "4",
"balanceInfo": CreateBalanceInfoInput,
"transactionId": "4"
}
CreateBalanceResult
Description
Return type of DeleteBalance including all possible errors.
TransactionHasBeenProcessed (TransactionHasBeenProcessed)- The transaction has been processed.InvalidField (InvalidLimit)- The limit has to be an integer value if it is not a rate based balance. Only rate based balance types can have decimal limits.AccountNotFound (AccountNotFound)- The specified account does not exist.BalanceTypeNotFound (BalanceTypeNotFound)- None of the balance type IDs provided does exist.InvalidField (BalanceLimitViolation)- When the balance total exceeds the balance or balance type limit or limit exceeds the limit in balance type.
Example
BalancePayload
CreateBalanceTypeInput
Description
Input type for creating a new balance type.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Provider ID. |
name - String!
|
Name of the balance type. Has to be unique across a tenant. |
unitType - UnitType!
|
Unit type of the balance type. |
limit - Float
|
Limit of the balance type. If the balance is rate based, it is equivalent creditLimit. |
rateBased - Boolean!
|
Whether it is a rate based balance type like a monetary balance or an allowance based type that is in units. If it is a rate based type, then decimal limits are allowed, otherwise, they aren't. |
counters - [BalanceTypeCounterInput!]
|
List of balance type counter inputs of the balance type. |
Example
{
"providerId": "4",
"name": "xyz789",
"unitType": "TIME",
"limit": 123.45,
"rateBased": false,
"counters": [BalanceTypeCounterInput]
}
CreateBalanceTypeResult
Description
Return type of CreateBalanceType including all possible errors.
BalanceTypeNameInUse (BalanceTypeNameInUse)- The balance type name is already in use.InvalidField (InvalidLimit)- The limit has to be an integer value if it is not a rate based balance type. Only rate based balance types can have decimal limits.InvalidField (InvalidCounterName)- The provided counter name must be between 1 and 50 characters and consist of letters, digits or special characters.InvalidField (InvalidCounterNames)- Counter names must be unique across the balance type.InvalidField (InvalidCounterStates)- Thresholds and names of states must be unique across the counter and one of the states must not have a threshold.
Types
| Union Types |
|---|
Example
BalanceTypePayload
CreateClientCredentialsInput
Description
Input type for createClientCredentials API. The email for this would be fetched directly from the user/token calling.
Fields
| Input Field | Description |
|---|---|
name - String!
|
A descriptive name for the client credentials. |
roleGroupMemberships - [RoleGroup!]!
|
The roles this user belong to |
Example
{
"name": "xyz789",
"roleGroupMemberships": ["Account_Query"]
}
CreateClientCredentialsPayload
Description
Return type of createClientCredentials API.
Fields
| Field Name | Description |
|---|---|
clientCredentials - ClientCredentials!
|
The created client credentials. |
secret - String!
|
The generated secret for the client credentials. |
Example
{
"clientCredentials": ClientCredentials,
"secret": "xyz789"
}
CreateClientCredentialsResult
Description
Return type of createClientCredentials, including all possible errors.
ProviderNotFound- The specifiedproviderIddoes not exist.InvalidField (InvalidEmail)- The provided email is incorrectly formattedInvalidField (RoleGroupMemberships)- A non-valid role group was providedClientCreationLimitExceeded- There are more than 10 clients already created for this provider
Example
CreateClientCredentialsPayload
CreateDeviceInput
Description
Input type of CreateDevice.
Example
{
"providerId": 4,
"accountId": "4",
"deviceId": 4,
"customData": AWSJSON
}
CreateDevicePayload
Description
Return type of CreateDevice.
Fields
| Field Name | Description |
|---|---|
device - Device!
|
The created device. |
Example
{"device": Device}
CreateDeviceResult
Description
Return type of CreateDevice including all possible errors.
InvalidField (InvalidJsonCustomData)- The provided customData is an invalid JSON.
Example
CreateDevicePayload
CreateFieldMappingInput
Description
Input type of CreateFieldMapping.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
path - String!
|
The path to the field you want to manipulate. For example, "transformedRequest.sMSChargingInformation.numberofMessagesSent". The path must start from either "transformedRequest." or "transformedResponse." and might be existing path or not existing. If provided path does not exist in request or response, only the last key should not exist. For example, "transformedResponse.invocationResult.message" is allowed, while "transformedResponse.invocationResult.message.text" is not allowed, because message is a new key already. It is possible to set a new field to a list. Originally SpEL does not support that, but we iterate over lists with provided [] after them. For example, "transformedRequest.multipleUnitUsage[].usedUnitContainer[].timeSpecificUnits", both multipleUnitUsage and usedUnitContainer are arrays, it means eventually field mapper will add to each item in these lists a new key "timeSpecificUnits". For the N28/SY interface, the path must start from either "transformedN28Request" or "transformedN28Response". You can then set the custom "tenantIdentifier" field by using the path "transformedN28Request.tenantIdentifier". This field can and will not be set on deleting spending limit subscriptions but the subscription ID will be used. |
expr - String!
|
SpEL expression to generate the value(s). It must return one value, but also it can use the same expressions as "path" with []. For example, "originalRequest.multipleUnitUsage[].usedUnitContainer[].serviceSpecificUnits * 10". It is also possible to use "originalField" as a reference to original value if field exists. For example, "originalField + 10". For the N28/SY interface, the expression must start with either "originalN28Request" or "originalN28Response". |
Example
{
"providerId": 4,
"path": "transformedRequest.multipleUnitUsage[].ratingGroup",
"expr": "originalField?:100"
}
CreateFieldMappingPayload
Description
Return type of CreateFieldMapping.
Fields
| Field Name | Description |
|---|---|
fieldMapping - FieldMapping!
|
Created field mapping. |
Example
{"fieldMapping": FieldMapping}
CreateFieldMappingResult
Description
Return type of CreateFieldMapping including all possible errors.
InvalidField (InvalidFieldMappingPath)- The provided field mapping path cannot be compiled.InvalidField (InvalidFieldMappingExpression)- The provided field mapping SpEL expression cannot be compiled.
Example
CreateFieldMappingPayload
CreateLifecycleInput
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
name - String!
|
Descriptive name |
customData - AWSJSON
|
Any custom data; typically only used by Plan Design UI. |
states - [LifecycleStateInput!]!
|
Lifecycle Definition; first state is used as the default. |
Example
{
"providerId": "4",
"name": "abc123",
"customData": AWSJSON,
"states": [LifecycleStateInput]
}
CreateLifecycleResult
Description
Return type of CreateAccount including all possible errors.
InvalidNumberOfStates (InvalidNumberOfStates)- The lifecycle requires at least one state.InvalidStateTransitions (InvalidStateTransitions)- Transitions need to be to a valid state.InvalidStateTransitions (InvalidExpiryState)- Transition state on expiry need to be in state's list of transitions.InvalidField (InvalidExpiryDays)- expiryDays exceed maxDays.InvalidField (InvalidCustomDataSize)- customData size exceeds max size.
Example
LifecyclePayload
CreatePlanFromInitialRecurringFirstUsageTemplateInput
Description
Input type of createPlanFromInitialRecurringFirstUsageTemplate.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
planId - ID
|
A new plan ID. Autogenerated if not provided. |
version - String!
|
The name of the first version. |
name - String!
|
A name for a new plan. |
recurringFirstUsageFee - Float!
|
A fee that will be charged every time after the recurringFirstUsagePeriod expires. Currently, this is at the next hour for hourly plans, at next midnight of the account timezone for daily plans, at next Saturday midnight of the account timezone for weekly plans, and at the last day of the month midnight of the account timezone for monthly plans. |
recurringFirstUsagePeriodType - PeriodType!
|
The period type at which the recurringFirstUsageFee is charged, hourly, daily, weekly, monthly. |
services - [InitialRecurringFirstUsageTemplateServiceInput!]!
|
List of plan services. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. Considered as 0 if not provided. |
policies - [PolicyInput!]
|
Policies to attach to the plan version for PCF policy negotiation |
Example
{
"providerId": 4,
"planId": "4",
"version": "xyz789",
"name": "abc123",
"recurringFirstUsageFee": 987.65,
"recurringFirstUsagePeriodType": "HOUR",
"services": [
InitialRecurringFirstUsageTemplateServiceInput
],
"json": AWSJSON,
"priority": 987.65,
"policies": [PolicyInput]
}
CreatePlanFromInitialTemplateInput
Description
Input type of CreatePlanFromInitialTemplate.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
planId - ID
|
A new plan ID. Autogenerated if not provided. |
version - String!
|
The name of the first version. |
name - String!
|
A name for a new plan. |
fee - Float
|
A fee that will be charged per specified recurring period. Recurring fee is charged first time after the first period. If you need to charge some fee on subscription you need to use purchaseFee. If not provided then no such fee is charged. |
firstUsageFee - Float
|
A fee that will be charged just once on first usage of the plan. If not provided then no such fee is charged. |
purchaseFee - Float
|
A fee that will be charged just once right after the subscription. If not provided then no such fee is charged. |
period - RecurringPeriodInput
|
A period when specified fee will be charged. If not provided then it is considered that plan never expires until cancellation and there are no recurring actions. |
services - [InitialTemplateServiceInput!]!
|
List of plan services. A plan service can only specify a monetary or unit rate but not both, they are exclusive. |
notificationPeriodsBeforeExpiration - [Int]
|
A set of periods in seconds when to send multiple notifications before the plan expires. |
renewalGracePeriod - [DurationInput]
|
Put a plan on hold for a limited grace period while waiting for a successful renewal. It is a sum of provided duration inputs. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. Considered as 0 if not provided. |
proratingOptions - ProratingOptionsInput
|
The prorating options for the plan |
policies - [PolicyInput!]
|
Policies to attach to the plan version for PCF policy negotiation |
Example
{
"providerId": 4,
"planId": 4,
"version": "xyz789",
"name": "abc123",
"fee": 123.45,
"firstUsageFee": 987.65,
"purchaseFee": 987.65,
"period": RecurringPeriodInput,
"services": [InitialTemplateServiceInput],
"notificationPeriodsBeforeExpiration": [123],
"renewalGracePeriod": [DurationInput],
"json": AWSJSON,
"priority": 987.65,
"proratingOptions": ProratingOptionsInput,
"policies": [PolicyInput]
}
CreatePlanFromInitialTemplateResult
Description
Return type of CreatePlanFromInitialTemplate including all possible errors.
InvalidField (InvalidExtendedRate)- In the roaming or long distance one of the inputs (origination or termination) must be provided.InvalidField (InvalidRatingGroup)- There is no provided rating group ID in the hierarchy or provided rating group ID is the Root.InvalidField (SubscriptionPolicy)- If "alignBillingToDoM" is set to false and "subscriptionPolicy" was anything other than NONE or emptyInvalidField (RefundPolicy)- If "alignBillingToDoM" is set to false and "refundPolicy" was anything other than NONE or emptyInvalidField (ProratingOptionsSetForNonMonthlyPlan)- If "alignBillingToDoM" is set to true for a non-monthly planInvalidField (InvalidRecurringFirstUsageFee)- recurringFirstUsageFee cannot be zero for recurring first usage templateBalanceTypeNotFound (BalanceTypeNotFound)- One of the provided balance type IDs does not exist.CreatePlanValidationFailed (FeeIsNotRequired)- Fee is provided for a non recurring plan. Recurring plan must have a period specified and this period must be marked as recurring.ServiceFormatError (ServiceFormatError)- A new version of a plan is created based on the old format while a version with the new format exists. As soon as a plan uses the new balance format, all versions of the plan must use the new format.
Example
CreatePlanPayload
CreatePlanPayload
Description
Return type of CreatePlanFromInitialTemplate.
Fields
| Field Name | Description |
|---|---|
plan - Plan!
|
Created plan. |
Example
{"plan": Plan}
CreatePlanResult
Description
Return type of CreatePlan including all possible errors.
InvalidField (InvalidName)- The provided name must be between 2 and 50 characters and consist of letters, digits or special characters.InvalidField (InvalidIsoDuration)- Expected a valid ISO 8601 duration string.InvalidField (InvalidPlanVersionInput)- PlanVersionInput must provide only one of the versions.InvalidField (InvalidVersionName)- The provided plan version name must be between 1 and 50 characters and consist of letters, digits or special characters.InvalidField (InvalidServiceName)- The provided name must be between 2 and 50 characters and consist of letters, digits or special characters.InvalidField (DuplicatedServiceName)- Service names must be unique across the plan version.InvalidField (InvalidRatingGroup)- There is no provided rating group ID in the hierarchy or provided rating group ID is the Root.InvalidField (EmptyBalanceTypes)-balanceTypesmust not be empty.InvalidField (InvalidBalanceTypeIds)- Balance Type Ids inbalanceTypeIdsmust be unique.InvalidField (InvalidBalanceTypes)- Balance Type Ids inbalanceTypesmust be unique.InvalidField (InvalidBalanceTypeIds)- All balance Type Ids inbalanceTypeIdsmust be Ids of either rate based balance types or not rate based balance types. Mixing is not allowed.InvalidField (InvalidBalanceTypes)- UnitPlanService only supports non-rate based balance types.InvalidField (InvalidManagedBalanceTypeId)-balanceTypeIdsdoes not include 'managedBalanceTypeId'.InvalidField (InvalidManagedBalanceTypes)-balanceTypesdoes not include 'managedBalanceTypeId'.InvalidField (MissingField)- The periodAllowance must be provided and must be greater than zero when managedBalance is used for unit plan services.InvalidField (InvalidRolloverSettings)- The fields maxRolloverPeriods, rolloverAllowance, rolloverMaxAllowance must not be provided if rollover is set to false.InvalidField (InvalidRolloverSettings)- Rollover, maxRolloverPeriods, rolloverAllowance, rolloverMaxAllowance must not be provided if periodAllowance is not provided or 0 (unlimited).InvalidField (InvalidInteger)- The provided number can be only an integer.InvalidField (ExpressionValidationFailed)- Invalid expression in service restrictions or rateOptions.restrictions.BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.PlanAlreadyExists (PlanAlreadyExists)- A plan with the provided ID already exists.PlanServiceValidationFailed (RateBalanceNotAllowedInUnlimitedService)- UnlimitedPlanService cannot use rate balance type.
Example
PlanPayload
CreatePlanValidationFailed
Description
An error type to be thrown if a plan cannot be created out of the provided input.
DuplicateCounterName- Two or more counters in a service have the same name.MissingCounterStates- One or more counter has no states. At least one state is required.DuplicateCounterStateName- Two or more counter states in a counter have the same name.MissingDefaultCounterState- A counter has no default state (a state with no threshold).DuplicateCounterStateThreshold- Two or more states of a counter have the same threshold.WrongCountryCodeExpression- The country code expression defines a non-restricting value set.RoamingConfigOverlapping- The roaming configuration includes overlapping entries. A start () includes all countries, having an entry with "" and one with "US" is overlapping "*" needs to be replaced with "!US".LongDistanceConfigOverlapping- The long distance configuration includes overlapping entries. A start () includes all countries, having an entry with "" and one with "US" is overlapping "*" needs to be replaced with "!US".TooManyEntries- The entry list for the roaming and long distance configuration has too many entries. 10k entries is the maximum.PlanServiceAllowanceIsUnlimited- If "periodAllowance" is not provided, the plan service is considered unlimited. "overage" is not needed.
Example
{
"errorCode": "xyz789",
"errorMessage": "abc123"
}
CreatePlanVersionFromInitialRecurringFirstUsageTemplateInput
Description
Input type of CreatePlanVersionFromInitialRecurringFirstUsageTemplate.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
planVersionId - ID!
|
An existing plan version ID to be updated or a base plan version ID for a new version. |
version - String!
|
The name of the new version. |
recurringFirstUsageFee - Float!
|
A fee that will be charged every time after the recurringFirstUsagePeriod expires. Currently, this is at the next hour for hourly plans, at next midnight of the account timezone for daily plans, at next Saturday midnight of the account timezone for weekly plans, and at the last day of the month midnight of the account timezone for monthly plans. |
recurringFirstUsagePeriodType - PeriodType!
|
The period type at which the recurringFirstUsageFee is charged, hourly, daily, weekly, monthly. |
services - [InitialRecurringFirstUsageTemplateServiceInput!]
|
List of plan services. If not provided used from the original version. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. If not provided used from the original version. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. If not provided used from the original version. |
policies - [PolicyInput!]
|
Policies to attach to the plan version for PCF policy negotiation |
Example
{
"providerId": 4,
"planVersionId": 4,
"version": "xyz789",
"recurringFirstUsageFee": 987.65,
"recurringFirstUsagePeriodType": "HOUR",
"services": [
InitialRecurringFirstUsageTemplateServiceInput
],
"json": AWSJSON,
"priority": 987.65,
"policies": [PolicyInput]
}
CreatePlanVersionFromInitialTemplateInput
Description
Input type of CreatePlanVersionFromInitialTemplate.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
planVersionId - ID!
|
An existing plan version ID to be updated or a base plan version ID for a new version. |
version - String!
|
The name of the new version. |
fee - Float
|
A fee that will be charged per specified recurring period. Recurring fee is charged first time after the first period. If you need to charge some fee on subscription you need to use purchaseFee. If not provided used from original version. |
firstUsageFee - Float
|
A fee that will be charged just once on first usage of the plan. If not provided used from original version. |
purchaseFee - Float
|
A fee that will be charged just once right after the subscription. If not provided used from original version. |
period - RecurringPeriodInput
|
A period when specified fee will be charged. If not provided used from original version. |
services - [InitialTemplateServiceInput!]
|
List of plan services. If not provided used from the original version. A plan service can only specify a monetary or unit rate but not both, they are exclusive. |
notificationPeriodsBeforeExpiration - [Int]
|
A set of periods in seconds when to send multiple notifications before the plan expires. If not provided and there's an original version, values are taken from there. |
renewalGracePeriod - [DurationInput]
|
Put a plan on hold for a limited grace period while waiting for a successful renewal. It is a sum of provided duration inputs. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. If not provided used from the original version. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. If not provided used from the original version. |
proratingOptions - ProratingOptionsInput
|
The prorating options for the plan |
policies - [PolicyInput!]
|
Policies to attach to the plan version for PCF policy negotiation |
Example
{
"providerId": 4,
"planVersionId": "4",
"version": "xyz789",
"fee": 123.45,
"firstUsageFee": 987.65,
"purchaseFee": 123.45,
"period": RecurringPeriodInput,
"services": [InitialTemplateServiceInput],
"notificationPeriodsBeforeExpiration": [987],
"renewalGracePeriod": [DurationInput],
"json": AWSJSON,
"priority": 987.65,
"proratingOptions": ProratingOptionsInput,
"policies": [PolicyInput]
}
CreatePlanVersionFromInitialTemplateResult
Description
Return type of CreatePlanVersionFromInitialTemplate including all possible errors.
InvalidField (InvalidExtendedRate)- In the roaming or long distance one of the inputs (origination or termination) must be provided.InvalidField (InvalidRatingGroup)- There is no provided rating group ID in the hierarchy or provided rating group ID is the Root.InvalidField (SubscriptionPolicy)- If "alignBillingToDoM" is set to false and "subscriptionPolicy" was anything other than NONE or emptyInvalidField (RefundPolicy)- If "alignBillingToDoM" is set to false and "refundPolicy" was anything other than NONE or emptyInvalidField (ProratingOptionsSetForNonMonthlyPlan)- If "alignBillingToDoM" is set to true for a non monthly planBalanceTypeNotFound (BalanceTypeNotFound)- One of the provided balance type IDs does not exist.CreatePlanValidationFailed (FeeIsNotRequired)- Fee is provided for a non recurring plan. Recurring plan must have a period specified and this period must be marked as recurring.CreatePlanValidationFailed (BaseVersionIsNotTemplate)- The specified planVersionId is not a template version.ServiceFormatError (ServiceFormatError)- A new version of a plan is created based on the old format while a version with the new format exists. As soon as a plan uses the new balance format, all versions of the plan must use the new format.
Example
PlanVersionPayload
CreateQoSProfilePayload
Description
Payload for successful QoS Profile creation.
Fields
| Field Name | Description |
|---|---|
qosProfile - QoSProfile!
|
The created QoS profile |
Example
{"qosProfile": QoSProfile}
CreateQoSProfileResult
Description
Result type for createQoSProfile mutation.
Types
| Union Types |
|---|
Example
CreateQoSProfilePayload
CreateUserInput
Description
Input type of CreateUser
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Service provider ID |
email - AWSEmail!
|
|
name - String!
|
The name of the user. Should be between 2 and 75 characters |
roleGroupMemberships - [RoleGroup!]!
|
The roles this user belong to |
phoneNumber - AWSPhone
|
The user's phone number |
jobTitle - String
|
The user's job title. If present, it should be between 2 and 50 characters |
expiry - AWSDateTime
|
The time when the user should expire. Used for temporary access. |
alertInterval - Int
|
The alarm interval in minutes when an email should be send to the user that access expires. Only used when expiry is specified. Can be 0 or not specified when expiry is specified which means no email is send. |
Example
{
"providerId": 4,
"email": AWSEmail,
"name": "abc123",
"roleGroupMemberships": ["Account_Query"],
"phoneNumber": AWSPhone,
"jobTitle": "xyz789",
"expiry": AWSDateTime,
"alertInterval": 987
}
CreateUserResult
Description
Return type of CreateUser including all possible errors.
InvalidField (name)- Name should be at least two characters long and a maximum of seventy fiveInvalidField (jobTitle)- Job title should be at least two characters long and a maximum of fiftyInvalidField (expiry)- Expiry needs to be in the future and needs to be a valid datetime stringInvalidField (alertInterval)- The alert interval can't be negativeInvalidField (InvalidEmailDomain)- The email domain is not allowed
Example
SaveUserPayload
DashboardConfig
Fields
| Field Name | Description |
|---|---|
dashboard - AWSURL
|
URL for the embedded dashboard. |
Example
{"dashboard": AWSURL}
DayOfMonthAlreadySet
Description
An error that is thrown when user tries to change DoM during the same cycle DoM was changed.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Provider ID. |
accountId - ID!
|
Account ID. |
billingDayOfMonth - Int!
|
The current value of the DoM. |
newBillingDayOfMonth - Int!
|
The updated value of the DoM. |
longFirstBillingCycle - Boolean
|
The current value of the long billing cycle. |
newLongFirstBillingCycle - Boolean
|
The updated value of the long billing cycle. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"providerId": "4",
"accountId": "4",
"billingDayOfMonth": 987,
"newBillingDayOfMonth": 987,
"longFirstBillingCycle": true,
"newLongFirstBillingCycle": true,
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
DeleteAccountBalanceTypeCounterInput
Description
Input parameters for deleting a Balance Type Counter for an account. Deletes an AccountBalanceCounter record.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Provider ID. |
balanceTypeCounterId - ID!
|
The unique identifier for the Balance Type Counter to be deleted. |
balanceTypeId - ID!
|
The unique identifier for the Balance Type where the counter should be be deleted. |
accountId - ID!
|
The Account ID associated with the Balance Type Counter. |
Example
{
"providerId": "4",
"balanceTypeCounterId": "4",
"balanceTypeId": 4,
"accountId": "4"
}
DeleteAccountBalanceTypeCounterPayload
Description
Return type when deleting a Balance Type Counter
Example
{
"deletedBalanceTypeCounterId": 4,
"accountId": "4",
"balanceTypeId": "4"
}
DeleteAccountBalanceTypeCounterResult
Description
Return type of Balance Type Counter including all possible errors.
AccountNotFound (AccountNotFound)- The specified account does not exist.AccountBalanceTypeCounterNotFound (AccountBalanceTypeCounterNotFound)- The specified counter does not exist in the account.BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.
Example
DeleteAccountBalanceTypeCounterPayload
DeleteAccountInput
Description
Input type of DeleteAccount.
Example
{
"providerId": "4",
"accountId": "4",
"transactionId": "4"
}
DeleteAccountPayload
Description
Return type of DeleteAccount.
Example
{
"deletedAccountId": "4",
"parentAccount": Account,
"transactionId": 4
}
DeleteAccountResult
Description
Return type of DeleteAccount including all possible errors.
Example
DeleteAccountPayload
DeleteBalanceInput
Description
Input type for deleting a balance.
Example
{
"balanceTypeId": 4,
"balanceId": 4,
"providerId": 4,
"accountId": 4,
"transactionId": "4"
}
DeleteBalancePayload
DeleteBalanceResult
Description
Return type of DeleteBalance including all possible errors.
TransactionHasBeenProcessed (TransactionHasBeenProcessed)- The transaction has been processed.BalanceHasReferences (BalanceHasReferences)- The balance is used in an active plan and can't be deleted.BalanceNotFound (BalanceNotFound)- The balance ID provided does not exist.AccountNotFound (AccountNotFound)- The specified account does not exist.BalanceTypeNotFound (BalanceTypeNotFound)- None of the balance type IDs provided does exist.
Example
DeleteBalancePayload
DeleteBalanceTypeCounterInput
Description
Input parameters for deleting a Balance Type Counter.
Example
{
"providerId": "4",
"balanceTypeCounterId": 4,
"balanceTypeId": 4
}
DeleteBalanceTypeCounterPayload
Description
Return type when deleting a Balance Type Counter
Example
{"deletedBalanceTypeCounterId": 4, "balanceTypeId": 4}
DeleteBalanceTypeCounterResult
Description
Return type of Balance Type Counter including all possible errors.
BalanceTypeCounterNotFound (BalanceTypeCounterNotFound)- The balance type counter ID provided does not exist.BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.
Example
DeleteBalanceTypeCounterPayload
DeleteBalanceTypeInput
DeleteBalanceTypePayload
Description
Return type when deleting a balance type
Fields
| Field Name | Description |
|---|---|
deletedBalanceTypeId - ID!
|
The ID of the balance type that has been deleted. |
Example
{"deletedBalanceTypeId": 4}
DeleteBalanceTypeResult
Description
Return type of DeleteBalanceType including all possible errors.
BalanceTypeHasReferences (BalanceTypeHasReferences)- The balance type is used in an active plan and can't be deleted.BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.
Example
DeleteBalanceTypePayload
DeleteClientCredentialsPayload
DeleteClientCredentialsResult
Description
Return type of deleteClientCredentials, including all possible errors.
ProviderNotFound- The specifiedproviderIddoes not exist.ClientNotFound- The specified client credentialsiddoes not exist.
Types
| Union Types |
|---|
Example
DeleteClientCredentialsPayload
DeleteDeviceInput
Description
Input type of DeleteDevice.
Example
{
"providerId": "4",
"accountId": "4",
"deviceId": 4
}
DeleteDevicePayload
DeleteDeviceResult
Description
Return type of DeleteDevice including all possible errors.
Example
DeleteDevicePayload
DeleteFieldMappingInput
DeleteFieldMappingPayload
Description
Return type of DeleteFieldMapping.
Fields
| Field Name | Description |
|---|---|
deletedPath - ID!
|
A path of a field mapping that has been deleted. |
Example
{"deletedPath": "4"}
DeleteFieldMappingResult
Description
Return type of DeleteFieldMapping including all possible errors.
Example
DeleteFieldMappingPayload
DeleteLifecycleInput
DeleteLifecyclePayload
Fields
| Field Name | Description |
|---|---|
lifecycleId - ID!
|
The created lifecycle. |
Example
{"lifecycleId": 4}
DeleteLifecycleResult
Description
Return type of CreateAccount including all possible errors.
LifecycleNotFound (LifecycleNotFound)- The specified lifecycle doesn't exist.
Example
DeleteLifecyclePayload
DeletePlanInput
Description
Input type of DeletePlan. Important: This input field is used by old template API and is deprecated. For the new Beta API for RA plans specify it in the arguments instead. Deprecated date is 2025-06-01. Expiration date is 2025-09-01.
Example
{"providerId": 4, "planId": "4"}
DeletePlanPayload
Description
Return type of DeletePlan.
Example
{
"deletedPlanId": "4",
"deletedPlanVersions": [4],
"deletedPlanServices": [4]
}
DeletePlanResult
Description
Return type of DeletePlan including all possible errors.
Example
DeletePlanPayload
DeletePlanVersionInput
DeletePlanVersionPayload
DeletePlanVersionResult
Description
Return type of DeletePlanVersion including all possible errors.
Example
DeletePlanVersionPayload
DeleteQoSProfilePayload
Description
Payload for successful QoS Profile deletion.
Fields
| Field Name | Description |
|---|---|
deletedQoSProfileId - ID!
|
The ID of the deleted QoS profile |
Example
{"deletedQoSProfileId": "4"}
DeleteQoSProfileResult
Description
Result type for deleteQoSProfile mutation.
Types
| Union Types |
|---|
Example
DeleteQoSProfilePayload
DeleteUserInput
DeleteUserPayload
DeleteUserResult
Example
DeleteUserPayload
DeployFieldMappingsInput
Description
Input type of DeployFieldMappings.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
paths - [String!]
|
Deploys only provided list of fields. If not provided then all field mappings are replaced. If provided then all configurations applied after "from" date are updated with provided set of fields. |
from - AWSDateTime
|
The date when current set of field mappings take effect in the system. If not provided then considered as now. All the configurations after this date are either updated with provided paths or removed if paths are not provided. |
Example
{
"providerId": "4",
"paths": ["abc123"],
"from": AWSDateTime
}
DeployFieldMappingsPayload
Description
Return type of DeployFieldMappings.
Fields
| Field Name | Description |
|---|---|
deployedFieldMapping - DeployedFieldMapping!
|
Example
{"deployedFieldMapping": DeployedFieldMapping}
DeployFieldMappingsResult
Description
Return type of DeployFieldMappings including all possible errors.
Example
DeployFieldMappingsPayload
DeployPlanVersionInput
Description
Input type of DeployPlanVersion.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
planVersionId - ID!
|
A unique identifier of a planVersion version to deploy. If another version of the same common plan has already been deployed, it will be made unassignable. |
migrateFromVersions - [ID!]
|
The list of plan version IDs to migrate from to this new deployed version. Automatically upgrade already subscribed accounts to the new version. Not required for a new deployment. If not specified considered as no auto migration is required. Note: This field is not supported for beta plans. Migration to or from beta plans is not available; please use aliases instead. |
alias - AliasInput
|
Optional alias deployment. If provided, an alias will be deployed with the new plan version. Other plan versions will only be made unassignable if the version is not referenced in the alias as a current or future version. |
Example
{
"providerId": 4,
"planVersionId": "4",
"migrateFromVersions": ["4"],
"alias": AliasInput
}
DeployPlanVersionResult
Description
Return type of DeployPlanVersion including all possible errors.
PlanVersionNotFound (PlanVersionNotFound)- The requested plan version with the provided ID cannot be found.DeploymentVerificationFailed (PlanServiceConfigIsNotComplete)- The plan contains plan service configuration(s) that are not complete to provide enough information for charging / crediting.DeploymentVerificationFailed (PlanIsReadOnly)- The requested plan is an initial plan and cannot be deployed.MigrationAlreadyInProgress (MigrationAlreadyInProgress)- Another migration on the same plan can be done only when the current migration is finished.PlanVersionWrongTransition (PlanVersionIsAlreadyInState)- The plan version is already in the correct state. Transition is not required.InternalServerError (ChargeEngineNotAvailable)- The charge engine is not available at this time.
Example
PlanVersionPayload
DeployedFieldMapping
Description
Field mappings that have been deployed and take effect starting from some date.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
from - AWSDateTime!
|
The date when current set of field mappings take effect in the system. |
fieldMappings - FieldMappingConnection!
|
A list of deployed field mappings. |
Example
{
"providerId": 4,
"from": AWSDateTime,
"fieldMappings": FieldMappingConnection
}
DeployedFieldMappingConnection
Description
The connection type for DeployedFieldMapping.
Fields
| Field Name | Description |
|---|---|
edges - [DeployedFieldMappingEdge!]
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
Example
{
"edges": [DeployedFieldMappingEdge],
"pageInfo": PageInfo
}
DeployedFieldMappingEdge
Description
An edge in a connection.
Fields
| Field Name | Description |
|---|---|
node - DeployedFieldMapping!
|
The item at the end of the edge. |
cursor - String!
|
A cursor for use in pagination. |
Example
{
"node": DeployedFieldMapping,
"cursor": "abc123"
}
DeploymentVerificationFailed
Description
An error type to be thrown if a plan failed verification on deployment.
Example
{
"providerId": 4,
"planVersionId": 4,
"errorCode": "abc123",
"errorMessage": "xyz789"
}
Device
Description
The smallest unit in the Charging Engine which represents an end user and belongs to an account.
Example
{
"providerId": 4,
"id": "4",
"account": Account,
"customData": AWSJSON
}
DeviceAlreadyExists
Description
An error type to be thrown if a device with provided ID already exists.
Example
{
"deviceId": "4",
"errorCode": "abc123",
"errorMessage": "xyz789"
}
DeviceIdSelector
Description
Possible values for deviceIdSelector.
Values
| Enum Value | Description |
|---|---|
|
|
To take the device id from PDUSessionChargingInformation > userInformation > servedGpsi for charging or gpsi for spending limit control. |
|
|
To take the device id from subscriberIdentifier for charging or supi for spending limit control. This is the default value. |
Example
"SERVED_GPSI"
DeviceNotFound
Description
An error type to be thrown if a device was not found.
Example
{
"providerId": 4,
"deviceId": "4",
"errorCode": "abc123",
"errorMessage": "abc123"
}
DeviceResult
Description
Return type of Device including all possible errors.
Types
| Union Types |
|---|
Example
Device
Duration
Description
A time-based amount of time, such as '34.5 seconds'
Fields
| Field Name | Description |
|---|---|
amount - Int!
|
The amount of the duration, measured in terms of the unit. |
unit - PeriodType!
|
The unit that the duration is measured in. |
Example
{"amount": 123, "unit": "HOUR"}
DurationInput
Description
Input type for some time period. For example, 2w, 1d, 30m, etc.
Fields
| Input Field | Description |
|---|---|
type - PeriodType!
|
Determines a period. |
value - Int!
|
The number of period types to calculate the final time period. |
Example
{"type": "HOUR", "value": 123}
Error
EventDataRecord
Description
Represents an event in the Charging Engine.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a record. |
createdAt - AWSDateTime!
|
When the record was created. |
action - EventDataRecordAction!
|
Event action. |
customData - AWSJSON
|
Any custom data of the record. |
eventData - AWSJSON
|
Arbitrary event data. |
correlationId - String
|
A correlation identifier to group related event data records. |
Example
{
"providerId": "4",
"id": "4",
"createdAt": AWSDateTime,
"action": "subscribeToPlan",
"customData": AWSJSON,
"eventData": AWSJSON,
"correlationId": "abc123"
}
EventDataRecordAccountConnection
Description
The connection type for EventDataRecord.
Fields
| Field Name | Description |
|---|---|
edges - [EventDataRecordEdge!]
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
account - Account!
|
All of the EDRs belong to this account. |
Example
{
"edges": [EventDataRecordEdge],
"pageInfo": PageInfo,
"account": Account
}
EventDataRecordAccountConnectionResult
Description
Return type of EventDataRecordAccountConnection including all possible errors.
Example
EventDataRecordAccountConnection
EventDataRecordAction
Description
Possible actions in event data records.
Values
| Enum Value | Description |
|---|---|
|
|
An account has been subscribed to some plan. |
|
|
An existing subscription has been activated. |
|
|
An existing subscription has been changed. |
|
|
An existing subscription has been migrated. |
|
|
An existing subscription has been cancelled. |
|
|
An existing subscription has expired. |
|
|
A recurring fee has been charged from an account. |
|
|
A purchase fee has been charged from an account. |
|
|
A first usage fee has been charged from an account. |
|
|
A recurring first usage fee has been charged from an account. |
|
|
Postpaid account has been reset. |
|
|
A credit event has happened. |
|
|
A debit event has happened. |
|
|
Create a spending limit subscription. |
|
|
A charge event has happened. |
|
|
A counter threshold has been crossed and a notification has been sent. |
|
|
A counter threshold has been crossed and a notification has been sent. (Old) |
|
|
A device has been deleted. |
|
|
An account has been created. |
|
|
A device has been created. |
|
|
An account has been updated. |
|
|
An account has been deleted. |
|
|
A device as been updated. |
|
|
A new plan has been created. This API action is going to be replaced by BETA action in the future. |
|
|
A new plan has been created. |
|
|
A new plan version has been created. |
|
|
A new plan version has been created. |
|
|
A plan version has been updated. This API action is going to be replaced by BETA action in the future. |
|
|
A plan version has been updated. |
|
|
A plan has been updated. This API is not supported anymore. |
|
|
A plan has been updated. |
|
|
A plan has been deleted. This API action is going to be replaced by BETA action in the future. |
|
|
A plan has been deleted. |
|
|
A plan has been deployed. This API action is going to be replaced by BETA action in the future. |
|
|
A plan has been deployed. |
|
|
A plan version has been archived. This API action is going to be replaced by BETA action in the future. |
|
|
A plan version has been archived. |
|
|
A plan version has been deleted. This API action is going to be replaced by BETA action in the future. |
|
|
A plan version has been deleted. |
|
|
A plan has been made assignable. This API action is going to be replaced by BETA action in the future. |
|
|
A plan has been made assignable. |
|
|
A plan has been made not assignable. This API action was merged with makePlanAssignable. |
|
|
The rating group hierarchy has been updated. |
|
|
A new rating group hierarchy has been deployed. |
|
|
An account's churn score has been updated. |
|
|
Creation a balance on an account. |
|
|
Updating the balance of an account. |
|
|
Deleting the balance of an account. |
|
|
Creation of a lifecycle. |
|
|
Updating of a lifecycle. |
|
|
Deleting of a lifecycle. |
|
|
Updating the balance type of an account. |
|
|
General create. Will be used with different EDR types, e.g. POLICY. |
|
|
General update. Will be used with different EDR types, e.g. POLICY. |
|
|
General delete. Will be used with different EDR types, e.g. POLICY. |
Example
"subscribeToPlan"
EventDataRecordDeviceConnection
Description
The connection type for EventDataRecord.
Fields
| Field Name | Description |
|---|---|
edges - [EventDataRecordEdge!]
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
device - Device!
|
All of the EDRs belong to this device. |
Example
{
"edges": [EventDataRecordEdge],
"pageInfo": PageInfo,
"device": Device
}
EventDataRecordDeviceConnectionResult
Description
Return type of EventDataRecordDeviceConnection including all possible errors.
Example
EventDataRecordDeviceConnection
EventDataRecordEdge
Description
An edge in a connection.
Fields
| Field Name | Description |
|---|---|
node - EventDataRecord!
|
The item at the end of the edge. |
cursor - String!
|
A cursor for use in pagination. |
Example
{
"node": EventDataRecord,
"cursor": "xyz789"
}
EventDataRecordFilter
Description
Filtering options for event data records.
Fields
| Input Field | Description |
|---|---|
types - [EventDataRecordType!]
|
If not provided, then it is considered that all types are included. |
from - AWSDateTime
|
Return EDRs created only at this time or later. |
to - AWSDateTime
|
Return EDRs created only earlier than this time. |
Example
{
"types": ["CHARGING"],
"from": AWSDateTime,
"to": AWSDateTime
}
EventDataRecordType
Description
Possible types of event data records.
Values
| Enum Value | Description |
|---|---|
|
|
Charging EDRs are created as part of "init" and "update" charging requests. |
|
|
Billing EDRs are created as part of "terminate" charging requests, and event based requests. |
|
|
Account EDRs are created as part of executing any account mutation, and each EDR includes the time of the transaction, the identifier of the user who made the change, the action taken, the changed account identifier and the changed attributes. |
|
|
Device EDRs are created as part of executing any device mutation, and each EDR includes the time of the transaction, the identifier of the user who made the change, the action taken, the changed device identifier and the changed attributes. |
|
|
Churn score EDRs are created for providers that have churnFeatureEnabled set to true on a regular basis when calculating the churn score for each account. An EDR record is created for each update to every account. Each EDR contains the time of the update, the account ID, account type (prepaid/postpaid), the previous churn score and the current churn score. |
|
|
Policy EDRs are created as part of N7 SM Policy Control API requests. Each EDR includes the account ID, device ID, policy ID, request payload and response payload. |
Example
"CHARGING"
ExportConfig
Description
output type for data export config.
Fields
| Field Name | Description |
|---|---|
awsAccountId - String!
|
AWS Account ID where the Iceberg table is located |
databaseName - String!
|
Database name containing the Iceberg table |
tableName - String!
|
Name of the Iceberg table |
s3BucketUri - String!
|
S3 bucket name in the form s3://bucket-name |
roleArn - String!
|
ARN in the tenant account that we assume when writing to the tenant table |
Example
{
"awsAccountId": "abc123",
"databaseName": "abc123",
"tableName": "abc123",
"s3BucketUri": "abc123",
"roleArn": "abc123"
}
ExtendedRate
Description
Rate configuration for roaming.
Fields
| Field Name | Description |
|---|---|
origination - Origination
|
Information about A and B parties for MO calls. |
termination - Termination
|
Information about A and B parties for MT calls. |
rate - Rate
|
Rate configuration. If not provided means roaming for this origination is denied. |
Example
{
"origination": Origination,
"termination": Termination,
"rate": Rate
}
ExtendedRateInput
Description
Information about the rate for a plan. Either origination or termination must be provided. If no rate is provided, it is assumed that the rate is for long distance calls and origination is denied.
Fields
| Input Field | Description |
|---|---|
origination - OriginationInput
|
Information about A and B parties for MO calls. Either origination or termination must be provided. |
termination - TerminationInput
|
Information about A and B parties for MT calls. Either origination or termination must be provided. |
rate - RateInput
|
Rate configuration. If not provided means long distance for this number and origination is denied. |
Example
{
"origination": OriginationInput,
"termination": TerminationInput,
"rate": RateInput
}
FailureHandling
Description
Failure handling strategies
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
Example
"TERMINATE"
FeatureNotEnabled
Description
An error type to be thrown if a feature is not enabled.
Example
{
"providerId": "4",
"featureName": "xyz789",
"errorCode": "xyz789",
"errorMessage": "abc123"
}
FieldMapping
Description
Field mapping.
Fields
| Field Name | Description |
|---|---|
path - String!
|
The path to the field you want to manipulate. For example, "transformedRequest.sMSChargingInformation.numberofMessagesSent". The path must start from either "transformedRequest." or "transformedResponse." and might be existing path or not existing. If provided path does not exist in request or response, only the last key should not exist. For example, "transformedResponse.invocationResult.message" is allowed, while "transformedResponse.invocationResult.message.text" is not allowed, because message is a new key already. It is possible to set a new field to a list. Originally SpEL does not support that, but we iterate over lists with provided [] after them. For example, "transformedRequest.multipleUnitUsage[].usedUnitContainer[].timeSpecificUnits", both multipleUnitUsage and usedUnitContainer are arrays, it means eventually field mapper will add to each item in these lists a new key "timeSpecificUnits". |
expr - String!
|
SpEL expression to generate the value(s). It must return one value, but also it can use the same expressions as "path" with []. For example, "originalRequest.multipleUnitUsage[].usedUnitContainer[].serviceSpecificUnits * 10". It is also possible to use "originalField" as a reference to original value if field exists. For example, "originalField + 10". |
Example
{
"path": "transformedRequest.multipleUnitUsage[].ratingGroup",
"expr": "originalField?:100"
}
FieldMappingAlreadyExists
FieldMappingConnection
Description
The connection type for FieldMapping.
Fields
| Field Name | Description |
|---|---|
edges - [FieldMappingEdge!]
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
Example
{
"edges": [FieldMappingEdge],
"pageInfo": PageInfo
}
FieldMappingEdge
Description
An edge in a connection.
Fields
| Field Name | Description |
|---|---|
node - FieldMapping!
|
The item at the end of the edge. |
cursor - String!
|
A cursor for use in pagination. |
Example
{
"node": FieldMapping,
"cursor": "xyz789"
}
FieldMappingHasReferences
Description
An error type to be thrown if a field mapping has references preventing it from deletion.
Fields
| Field Name | Description |
|---|---|
fieldMapping - FieldMapping!
|
A field mapping with has references preventing it from deletion. |
errorCode - String!
|
|
errorMessage - String
|
Example
{
"fieldMapping": FieldMapping,
"errorCode": "abc123",
"errorMessage": "xyz789"
}
FieldMappingNotFound
Description
An error type to be thrown if a field mapping was not found.
Example
{
"providerId": 4,
"path": "xyz789",
"errorCode": "abc123",
"errorMessage": "xyz789"
}
Float
Description
The Float scalar type represents signed double-precision fractional values as specified by IEEE 754.
Example
123.45
GetAccountBalanceTypeCountersInput
Description
Input parameters for retrieving Balance Type Counter notifications for an account.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
accountId - ID!
|
The account ID associated with the Balance Type Counter. Retrieves the Balance Type Counter records from the account. |
balanceTypeId - ID!
|
The Balance Type associated with the counter. Retrieves the Balance Type Counter records for the Balance Type. |
balanceTypeCounterId - ID
|
The optional unique identifier of the Balance Type Counter. If specified, retrieves only the Balance Type Counter record with that ID. |
Example
{
"providerId": 4,
"accountId": "4",
"balanceTypeId": "4",
"balanceTypeCounterId": "4"
}
GetBalanceTypeCountersInput
Description
Input parameters for retrieving Balance Type Counters.
Fields
| Input Field | Description |
|---|---|
balanceTypeCounterId - ID
|
The optional unique identifier for the Balance Type Counter. If provided retrieves the single Balance Type Counter from the Balance Type. |
balanceTypeId - ID!
|
The Balance Type associated with the counter. Retrieves the Balance Type Counter records from the Balance Type. |
providerId - ID!
|
Provider ID. |
Example
{
"balanceTypeCounterId": 4,
"balanceTypeId": "4",
"providerId": "4"
}
GetBalanceTypeCountersResult
Description
Return type of several BalanceTypeCounter including all possible errors.
BalanceTypeCounterNotFound (BalanceTypeCounterNotFound)- The balance type ID provided does not exist.BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.
Example
BalanceTypeCountersPayload
GetBalanceTypeInput
GetBalanceTypeResult
Description
Return type of GetBalanceType including all possible errors.
BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.
Types
| Union Types |
|---|
Example
BalanceTypePayload
GetBalanceTypesInput
Description
Input type for getting balance types data. Returns only IDs that are found. If none of the specified are found, returns an error.
Example
{"balanceTypeIds": [4], "providerId": 4}
GetBalanceTypesPayload
Description
Balance type return type for getting multiple balance types.
Fields
| Field Name | Description |
|---|---|
balanceTypes - [BalanceTypePayload!]
|
The found balance types. |
Example
{"balanceTypes": [BalanceTypePayload]}
GetBalanceTypesResult
Description
Return type of GetBalanceTypes including all possible errors.
BalanceTypeNotFound (BalanceTypeNotFound)- None of the balance type IDs provided does exist.
Types
| Union Types |
|---|
Example
GetBalanceTypesPayload
GetClientCredentialsResult
Description
Return type of getClientCredentials, including all possible errors.
ProviderNotFound- The specifiedproviderIddoes not exist.ClientNotFound- The specified client credentialsiddoes not exist.
Types
| Union Types |
|---|
Example
ClientCredentials
GetLifecycleResult
Description
Return type of CreateAccount including all possible errors.
InvalidNumberOfStates (InvalidNumberOfStates)- The lifecycle requires at least one state.InvalidStateTransitions (InvalidStateTransitions)- Transitions need to be to a valid state.LifecycleNotFound (LifecycleNotFound)- The specified lifecycle doesn't exist.
Types
| Union Types |
|---|
Example
Lifecycle
GetLifecyclesResult
Description
Return type of GetLifecycles including all possible errors.
LifecycleNotFound (LifecycleNotFound)- The specified lifecycle doesn't exist.
Types
| Union Types |
|---|
Example
Lifecycles
GetMyDashboardResult
Types
| Union Types |
|---|
Example
DashboardConfig
GetMyProviderConfigResult
Description
Return type of GetMyProviderConfig including all possible errors.
InvalidProviderLifecycleStage- Provider user can't call API when provider lifecycle stage is CREATING, SUSPENDED, TERMINATED or DELETED.
Types
| Union Types |
|---|
Example
ProviderConfig
GetMyRestoreJobsInput
Description
Input type for GetMyRestoreJobs.
Fields
| Input Field | Description |
|---|---|
jobId - ID
|
Optional ID to get info of a specific job. If not passed, then we list jobs. |
from - AWSDateTime
|
Optional date/time in UTC to get the jobs created after (inclusive). If jobId is used, job exists, but doesn't match 'from', then an empty result is returned. |
to - AWSDateTime
|
Date/time in UTC to get the jobs created before (inclusive). If jobId is used, job exists, but doesn't match 'to', then an empty result is returned. |
Example
{
"jobId": 4,
"from": AWSDateTime,
"to": AWSDateTime
}
GetMyRestoreJobsPayload
Description
Return type for GetMyRestoreJobs.
Fields
| Field Name | Description |
|---|---|
jobs - [RestoreJob]!
|
The ID for the job. |
Example
{"jobs": [RestoreJob]}
GetMyRestoreJobsResult
Description
Return type of GetMyRestoreJobs including all possible errors.
InvalidField(from)- From field must be before to.
Types
| Union Types |
|---|
Example
GetMyRestoreJobsPayload
GetQoSProfileResult
Description
Result type for getQoSProfile query.
Types
| Union Types |
|---|
Example
QoSProfile
GetQoSProfilesResult
Description
Result type for getQoSProfiles query.
Example
QoSProfileConnection
GetRelatedAccountsByDevicePayload
Description
Return type of getRelatedAccountsByDevice
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. This is retrieved from cognito group named Provider_{providerId} |
deviceId - ID!
|
Device id for which the related accounts are returned |
accounts - [Account!]!
|
Accounts the device is related to |
Example
{
"providerId": "4",
"deviceId": 4,
"accounts": [Account]
}
GetRelatedAccountsByDeviceResult
Description
Return type of GetRelatedAccountsByDevice including all possible errors.
DeviceNotFound- Given device ID does not exist in the tenant
Types
| Union Types |
|---|
Example
GetRelatedAccountsByDevicePayload
GetUserInput
GetUserPayload
Description
Return type of a User for queries fetching a user or listing a group of them
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. This is retrieved from cognito group named Provider_{providerId} |
userId - ID!
|
Cognito User ID |
email - AWSEmail!
|
User email |
name - String
|
The name of the user |
roleGroupMemberships - [RoleGroup!]!
|
The roles this user belong to |
profilePicture - ProfilePhoto
|
The user's profile picture. If profile picture exists, it will always contain a pre-signed URL to download profile picture. It will contain pre-signed URL to upload picture only for the updateUserProfile mutation |
phoneNumber - AWSPhone
|
The user's phone number |
jobTitle - String
|
The user's job title |
softwareMfaEnabled - Boolean!
|
Whether the user has enabled software MFA or not |
expiry - AWSDateTime
|
The time when the user should expire. Used for temporary access. |
alertInterval - Int
|
The alarm interval in minutes when an email should be send to the user that access expires. Only used when expiry is specified. Can be 0 or not specified when expiry is specified which means no email is send. |
Example
{
"providerId": "4",
"userId": "4",
"email": AWSEmail,
"name": "xyz789",
"roleGroupMemberships": ["Account_Query"],
"profilePicture": ProfilePhoto,
"phoneNumber": AWSPhone,
"jobTitle": "xyz789",
"softwareMfaEnabled": true,
"expiry": AWSDateTime,
"alertInterval": 987
}
GetUserResult
Description
Return type of GetUser including all possible errors.
UserNotFound- Given user ID does not exist for the given provider, even if provider does not exist.
Example
GetUserPayload
HttpHeader
HttpMethod
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Example
"PUT"
ID
Description
The ID scalar type represents a unique identifier, often used to refetch an object or as key for a cache. The ID type appears in a JSON response as a String; however, it is not intended to be human-readable. When expected as an input type, any string (such as "4") or integer (such as 4) input value will be accepted as an ID.
Example
4
InitialRecurringFirstUsageTemplateInstance
Description
All the parameters with which initial recurring first usage fee template was used to create a plan.
Fields
| Field Name | Description |
|---|---|
recurringFirstUsageFee - Float!
|
A fee that will be charged every time after the recurringFirstUsagePeriod expires. Currently, this is at the next hour for hourly plans, at next midnight of the account timezone for daily plans, at next Saturday midnight of the account timezone for weekly plans, and at the last day of the month midnight of the account timezone for monthly plans. |
recurringFirstUsagePeriodType - PeriodType!
|
The period type at which the recurringFirstUsageFee is charged, hourly, daily, weekly, monthly. |
services - [InitialRecurringFirstUsageTemplateService!]!
|
List of plan services. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. |
Example
{
"recurringFirstUsageFee": 987.65,
"recurringFirstUsagePeriodType": "HOUR",
"services": [InitialRecurringFirstUsageTemplateService],
"json": AWSJSON,
"priority": 987.65
}
InitialRecurringFirstUsageTemplateService
Description
All the parameters for each service in initial recurring first usage template.
Fields
| Field Name | Description |
|---|---|
ratingGroupId - Int!
|
Custom rating group ID for this service. |
priority - Float
|
Plan service priority that determines the execution order for charging and rating. |
balanceTypeIds - [ID!]!
|
List of unique balance type IDs the plan service uses for charging if a balance of that type exists on the account. Balance type IDs could be, for example, manually added to the account and used if present or from another service. Order of the IDs specifies in what order the balances are applied on charging. |
rateBalance - RateBalance
|
Rate based balance configuration for this service. The configuration is used for any rate based balance type based on the order of input for the balance types. Premium numbers are only applicable to rate based balances. |
workingHours - [TimePeriod!]
|
A list of time periods when service is applicable. |
fromCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the origination party must be located in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
toCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the termination party must belong to an operator in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
bNumbersExpr - String
|
If provided, the MOC calls are restricted by the provided expression. It contains service(s). For example, for voice it consists of number(s) and it must match calledPartyAddress in 5G. Negation can be used. For example, !+12024561111. Conjunction can be used. For example, (+12024561111,+12024561414). |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. If both unit and monetary are not provided then requests that match provided ratingGroupId, workingHours, fromCountriesExpr, toCountriesExpr and bNumbersExpr are immediately failed without execution of all next services. By default it is false. |
restrictions - [ServiceConstraint]
|
The service allowance and rating can only be used if all the constraints listed are met. |
Example
{
"ratingGroupId": 123,
"priority": 123.45,
"balanceTypeIds": ["4"],
"rateBalance": RateBalance,
"workingHours": [TimePeriod],
"fromCountriesExpr": "xyz789",
"toCountriesExpr": "abc123",
"bNumbersExpr": "abc123",
"denyOtherServices": false,
"restrictions": ["IS_FRIEND_FAMILY"]
}
InitialRecurringFirstUsageTemplateServiceInput
Description
Input type for creating a recurring first usage service from a template. If parameters free, unit and monetary are not specified then service is denied completely. A plan service can only specify a monetary or unit rate but not both, they are exclusive.
Fields
| Input Field | Description |
|---|---|
ratingGroupId - Int!
|
Rating group ID for this service. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. Considered as 0 (the highest) if not provided. |
balanceTypeIds - [ID!]!
|
List of unique balance type IDs the plan service uses for charging if a balance of that type exists on the account. Balance type IDs could be, for example, manually added to the account and used if present or from another service. Order of the IDs specifies in what order the balances are applied on charging. |
rateBalance - RateBalanceInput
|
Rate based balance configuration for this service. The configuration is used for any rate based balance type based on the order of input for the balance types. Premium numbers are only applicable to rate based balances. |
workingHours - [TimePeriodInput!]
|
A list of time periods when service is applicable. |
fromCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the origination party must be located in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
toCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the termination party must belong to an operator in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
bNumbersExpr - String
|
If provided, the MOC calls are restricted by the provided expression. It contains service(s). For example, for voice it consists of number(s) and it must match calledPartyAddress in 5G. Negation can be used. For example, !+12024561111. Conjunction can be used. For example, (+12024561111,+12024561414). |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. If both unit and monetary are not provided then requests that match provided ratingGroupId, workingHours, fromCountriesExpr, toCountriesExpr and bNumbersExpr are immediately failed without execution of all next services. By default it is false. |
restrictions - [ServiceConstraint]
|
The service allowance and rating can only be used if all the constraints listed are met. Note: Do not include opposite restrictions together at the same time, such as IS_ON_NET and IS_OFF_NET. |
Example
{
"ratingGroupId": 123,
"priority": 987.65,
"balanceTypeIds": ["4"],
"rateBalance": RateBalanceInput,
"workingHours": [TimePeriodInput],
"fromCountriesExpr": "xyz789",
"toCountriesExpr": "abc123",
"bNumbersExpr": "abc123",
"denyOtherServices": false,
"restrictions": ["IS_FRIEND_FAMILY"]
}
InitialTemplateInstance
Description
All the parameters with which initial template was used to create a plan.
Fields
| Field Name | Description |
|---|---|
fee - Float
|
A fee that will be charged per specified recurring period. Recurring fee is charged first time after the first period. If you need to charge some fee on subscription you need to use purchaseFee. |
firstUsageFee - Float
|
A fee that will be charged just once on first usage of the plan. |
purchaseFee - Float
|
A fee that will be charged just once right after the subscription. |
period - RecurringPeriod
|
A period when specified fee will be charged. |
services - [InitialTemplateService!]!
|
List of plan services. A plan service can only specify a monetary or unit rate but not both, they are exclusive. |
notificationPeriodsBeforeExpiration - [Int]
|
A set of periods in seconds when to send multiple notifications before the plan expires. |
renewalGracePeriod - [Duration]
|
Put a plan on hold for a limited grace period while waiting for a successful renewal. It is a sum of provided durations. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. |
proratingOptions - ProratingOptions
|
The prorating options of the plan |
Example
{
"fee": 123.45,
"firstUsageFee": 123.45,
"purchaseFee": 123.45,
"period": RecurringPeriod,
"services": [InitialTemplateService],
"notificationPeriodsBeforeExpiration": [987],
"renewalGracePeriod": [Duration],
"json": AWSJSON,
"priority": 123.45,
"proratingOptions": ProratingOptions
}
InitialTemplateService
Description
All the parameters for each service in initial template. If parameters free, unit and monetary are not specified then service is denied completely. A plan service can only specify a monetary or unit rate but not both, they are exclusive.
Fields
| Field Name | Description |
|---|---|
ratingGroupId - Int!
|
Custom rating group ID for this service. |
priority - Float
|
Plan service priority that determines the execution order for charging and rating. |
balanceTypeIds - [ID!]
|
List of unique balance type IDs the plan service uses for charging if a balance of that type exists on the account. Only a single balance type ID is managed by the service. Other balance type IDs could be, for example, manually added to the account and used if present. Order of the IDs specifies in what order the balances are applied on charging. |
managedBalance - ManagedBalance
|
Managed balance configuration for this service. Roaming and long distance calls use this unit balance unless it is not restricted by from and to countries. Only unit and monetary or managedBalance and rateBalance can be specified but not both, they are exclusive. If the field is not specified, the service will not have a recurring allowance or rollover. For fair usage and unlimited plans, a balance type counter should be added to the specified balance type ID. |
rateBalance - RateBalance
|
Rate based balance configuration for this service. The configuration is used for any rate based balance type based on the order of input for the balance types. Premium numbers are only applicable to rate based balances. Only unit and monetary or managedBalance and rateBalance can be specified but not both, they are exclusive. |
workingHours - [TimePeriod!]
|
A list of time periods when service is applicable. |
fromCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the origination party must be located in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
toCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the termination party must belong to an operator in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
bNumbersExpr - String
|
If provided, the MOC calls are restricted by the provided expression. It contains service(s). For example, for voice it consists of number(s) and it must match calledPartyAddress in 5G. Negation can be used. For example, !+12024561111. Conjunction can be used. For example, (+12024561111,+12024561414). |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. If both unit and monetary are not provided then requests that match provided ratingGroupId, workingHours, fromCountriesExpr, toCountriesExpr and bNumbersExpr are immediately failed without execution of all next services. By default it is false. |
restrictions - [ServiceConstraint]
|
The service allowance and rating can only be used if all the constraints listed are met. |
Example
{
"ratingGroupId": 987,
"priority": 123.45,
"balanceTypeIds": [4],
"managedBalance": ManagedBalance,
"rateBalance": RateBalance,
"workingHours": [TimePeriod],
"fromCountriesExpr": "xyz789",
"toCountriesExpr": "abc123",
"bNumbersExpr": "abc123",
"denyOtherServices": false,
"restrictions": ["IS_FRIEND_FAMILY"]
}
InitialTemplateServiceInput
Description
Input type for creating a service from a template. If parameters free, unit and monetary are not specified then service is denied completely. A plan service can only specify a monetary or unit rate but not both, they are exclusive.
Fields
| Input Field | Description |
|---|---|
ratingGroupId - Int!
|
Rating group ID for this service. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. Considered as 0 (the highest) if not provided. |
balanceTypeIds - [ID!]
|
List of unique balance type IDs the plan service uses for charging if a balance of that type exists on the account. Only a single balance type ID is managed by the service. Other balance type IDs could be, for example, manually added to the account and used if present. Order of the IDs specifies in what order the balances are applied on charging. |
managedBalance - ManagedBalanceInput
|
Managed balance configuration for this service. Roaming and long distance calls use this unit balance unless it is not restricted by from and to countries. Only unit and monetary or managedBalance and rateBalance can be specified but not both, they are exclusive. If the field is not specified, the service will not have a recurring allowance or rollover. For fair usage and unlimited plans, a balance type counter should be added to the specified balance type ID. |
rateBalance - RateBalanceInput
|
Rate based balance configuration for this service. The configuration is used for any rate based balance type based on the order of input for the balance types. Premium numbers are only applicable to rate based balances. Only unit and monetary or managedBalance and rateBalance can be specified but not both, they are exclusive. |
workingHours - [TimePeriodInput!]
|
A list of time periods when service is applicable. |
fromCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the origination party must be located in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
toCountriesExpr - String
|
Applicable only for unit allowance. For monetary allowance, refer to roaming and longDistance fields in RateBalance. If provided, the termination party must belong to an operator in one of these countries for the service allowance and rating to be used. ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. |
bNumbersExpr - String
|
If provided, the MOC calls are restricted by the provided expression. It contains service(s). For example, for voice it consists of number(s) and it must match calledPartyAddress in 5G. Negation can be used. For example, !+12024561111. Conjunction can be used. For example, (+12024561111,+12024561414). |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. If both unit and monetary are not provided then requests that match provided ratingGroupId, workingHours, fromCountriesExpr, toCountriesExpr and bNumbersExpr are immediately failed without execution of all next services. By default it is false. |
restrictions - [ServiceConstraint]
|
The service allowance and rating can only be used if all the constraints listed are met. Note: Do not include opposite restrictions together at the same time, such as IS_ON_NET and IS_OFF_NET. |
Example
{
"ratingGroupId": 987,
"priority": 987.65,
"balanceTypeIds": [4],
"managedBalance": ManagedBalanceInput,
"rateBalance": RateBalanceInput,
"workingHours": [TimePeriodInput],
"fromCountriesExpr": "xyz789",
"toCountriesExpr": "abc123",
"bNumbersExpr": "abc123",
"denyOtherServices": true,
"restrictions": ["IS_FRIEND_FAMILY"]
}
InsufficientBalanceEventHandling
Description
Insufficient balance handling strategies for event-based charging
Values
| Enum Value | Description |
|---|---|
|
|
Deny the grant |
|
|
Grant the balance up to the rounding value with a Final Unit Indication |
Example
"REJECT"
InsufficientBalanceSessionHandling
Description
Insufficient balance handling strategies for session-based charging
Values
| Enum Value | Description |
|---|---|
|
|
Grant the amount as a multiple of the rounding unit that is less or equal to the requested amount. |
|
|
Grant the remaining balance amount with a Final Unit Indication |
|
|
Grant the balance up to the rounding value with a Final Unit Indication |
Example
"IGNORE"
Int
Description
The Int scalar type represents non-fractional signed whole numeric values. Int can represent values between -(2^31) and 2^31 - 1.
Example
987
InternalServerError
InvalidField
Description
An error type to be thrown if a value of a field in an input fails a validation.
Example
{
"fieldName": "xyz789",
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
InvalidNumberOfStates
InvalidProviderLifecycleStage
Description
An error type to be thrown if a provider's lifecycle state is not valid to execute the operation
Fields
| Field Name | Description |
|---|---|
providerLifecycleStage - ProviderLifecycleStage!
|
A name of the provider lifecycle stage. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"providerLifecycleStage": "CREATING",
"errorCode": "abc123",
"errorMessage": "xyz789"
}
InvalidStateTransitions
KeyValue
KeyValueInput
Description
Input type of KeyValue. This type is used in overrides which are key value pairs which can be nested. There are two main levels: plan and plan service.
- A simple plan override is the following: { name: "recurring period", value: "HOUR" }
- A nested override is used for plan services and can be like the following: "{ name: \"TemplateService0\", value: {\"recurring units":\"120\"} }" Pay attention to the format, it is a JSON, but as an escaped string because only strings are allowed as values. The same applies to inner values, such as recurring units, it must be also a string. A nested override uses the override field and value as the high-level value field with value. The following override fields are valid:
Field ReferencedField Type Scope Format alignToBillingDoM ProratingOptionsInput. alignToBillingDoM BOOLEAN Plan old and new fee fee NUMBER Plan old renewalFee fee NUMBER Plan new first usage fee firstUsageFee NUMBER Plan old firstUsageFee firstUsageFee NUMBER Plan new number of periods RecurringPeriodInput. numberOfPeriods NUMBER Plan old numberOfPeriods RecurringPeriodInput. numberOfPeriods NUMBER Plan new recurring RecurringPeriodInput. recurring BOOLEAN Plan old and new recurring period RecurringPeriodInput. numberOfPeriods STRING Plan old recurringPeriod RecurringPeriodInput. numberOfPeriods STRING Plan new refundPolicy ProratingOptionsInput. refundPolicy STRING(NONE /FULL_REFUND /TIME_BASED) Plan old and new renewalGracePeriod InitialTemplateInstance. renewalGracePeriod STRING Plan old and new subscriptionPolicy ProratingOptionsInput. subscriptionPolicy STRING (NONE / TIME_BASED) Plan old and new purchase fee InitialTemplateInstance. purchaseFee NUMBER Plan old purchaseFee InitialTemplateInstance. purchaseFee NUMBER Plan new periodAllowance ManagedBalance. periodAllowance NUMBER Plan -Service new rollover ManagedBalance.rollover BOOLEAN Plan Service maxRolloverPeriods ManagedBalance. maxRolloverPeriods NUMBER Plan-Service new rolloverAllowance ManagedBalance. rolloverAllowance NUMBER Plan-Service new rolloverMaxAllowance ManagedBalance. rolloverMaxAllowance NUMBER Plan-Service new chargeNewBalanceFirst ManagedBalance. chargeNewBalanceFirst BOOLEAN Plan-Service new workingHours InitialTemplateServiceInput. workingHours JSON Plan-Service old and new
Example
{
"name": "xyz789",
"value": "xyz789"
}
Lifecycle
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a Lifecycle. |
name - String!
|
Descriptive name |
states - [LifecycleState!]!
|
Lifecycle Definition; first state is used as the default. |
customData - AWSJSON
|
Any custom data; typically only used by Plan Design UI. |
Example
{
"providerId": 4,
"id": 4,
"name": "abc123",
"states": [LifecycleState],
"customData": AWSJSON
}
LifecycleExpiry
Example
{
"state": "abc123",
"days": 123,
"maxDays": 123
}
LifecycleExpiryInput
Fields
| Input Field | Description |
|---|---|
state - String!
|
State to transition to upon expiry - must be in the state's list of transitions |
days - Int
|
Number of days before the state automatically transitions - null means no expiry |
maxDays - Int
|
Maximum number of days that can be set for an account's expiry - null means unlimited expiry |
Example
{
"state": "xyz789",
"days": 987,
"maxDays": 987
}
LifecycleNotFound
Description
An error type to be thrown if a lifecycle defines an invalid state transition.
Example
{
"id": "4",
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
LifecyclePayload
Fields
| Field Name | Description |
|---|---|
lifecycle - Lifecycle!
|
The created lifecycle. |
Example
{"lifecycle": Lifecycle}
LifecycleState
Fields
| Field Name | Description |
|---|---|
name - String!
|
Name of State; used for specifying transitions |
transitions - [LifecycleTransition!]
|
Transitions to other states |
expiry - LifecycleExpiry
|
Automatic transition after an expiry period |
Example
{
"name": "xyz789",
"transitions": [LifecycleTransition],
"expiry": LifecycleExpiry
}
LifecycleStateInput
Fields
| Input Field | Description |
|---|---|
name - String!
|
Name of State; used for specifying transitions |
transitions - [LifecycleTransitionInput!]
|
Transitions to other states |
expiry - LifecycleExpiryInput
|
Automatic transition after an expiry period |
Example
{
"name": "xyz789",
"transitions": [LifecycleTransitionInput],
"expiry": LifecycleExpiryInput
}
LifecycleTransition
Fields
| Field Name | Description |
|---|---|
state - String!
|
Name of State to transition to |
Example
{"state": "abc123"}
LifecycleTransitionInput
Fields
| Input Field | Description |
|---|---|
state - String!
|
Name of State to transition to |
Example
{"state": "xyz789"}
Lifecycles
Description
Balance type return type for getting multiple balance types.
Fields
| Field Name | Description |
|---|---|
lifecycles - [Lifecycle!]
|
The found balance types. |
Example
{"lifecycles": [Lifecycle]}
ListAllClientCredentialsPayload
Description
Return type of listAllClientCredentials API. Pagination is not required over here as there is a limit of 10 clients per provider.
Fields
| Field Name | Description |
|---|---|
clientCredentials - [ClientCredentials!]!
|
Example
{"clientCredentials": [ClientCredentials]}
ListAllClientCredentialsResult
Description
Return type of listAllClientCredentials, including all possible errors.
ProviderNotFound- The specifiedproviderIddoes not exist.
Types
| Union Types |
|---|
Example
ListAllClientCredentialsPayload
ListUserPayload
Description
Return type of a User for queries fetching a user or listing a group of them
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. This is retrieved from cognito group named Provider_{providerId} |
userId - ID!
|
Cognito User ID |
email - AWSEmail!
|
User email |
name - String
|
The name of the user |
phoneNumber - AWSPhone
|
The user's phone number |
jobTitle - String
|
The user's job title |
expiry - AWSDateTime
|
The time when the user should expire. Used for temporary access. |
alertInterval - Int
|
The alarm interval in minutes when an email should be send to the user that access expires. Only used when expiry is specified. Can be 0 or not specified when expiry is specified which means no email is send. |
Example
{
"providerId": 4,
"userId": 4,
"email": AWSEmail,
"name": "xyz789",
"phoneNumber": AWSPhone,
"jobTitle": "abc123",
"expiry": AWSDateTime,
"alertInterval": 123
}
ListUsersConnection
Description
The connection type for ListUsers
Fields
| Field Name | Description |
|---|---|
edges - [ListUsersEdge!]!
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
Example
{
"edges": [ListUsersEdge],
"pageInfo": PageInfo
}
ListUsersEdge
Description
An edge in a user connection.
Fields
| Field Name | Description |
|---|---|
node - ListUserPayload!
|
The item at the end of the edge. |
cursor - String
|
A cursor for use in pagination. |
Example
{
"node": ListUserPayload,
"cursor": "abc123"
}
ListUsersResult
Description
Return type of ListUsers including all possible errors.
Types
| Union Types |
|---|
Example
ListUsersConnection
ManagedBalance
Description
Input type for the managed balance.
Fields
| Field Name | Description |
|---|---|
managedBalanceTypeId - ID!
|
The balance type ID that the plan service manages. Managing means that for this balance type ID, the service creates balances on subscription and renewal and handles rollover if specified. BalanceTypeIds must be provided if this is set and the referred balance type ID must be provided in balanceTypeIds. For fair usage and unlimited plans, a balance type counter should be added to the specified balance type ID. |
periodAllowance - Float
|
Value that the managed balance type ID will be created with. Can only be a decimal value for rate based balance types. If not specified or zero it means that it is unlimited. For fair usage and unlimited plans, a balance type counter should be added to the specified balance type ID. |
rollover - Boolean
|
An action to perform with balances from a previous period. Rollover if true or reset if false. False by default. |
maxRolloverPeriods - Int
|
The maximum number of periods a rollover is maintained. If rollover is set but this value isn't, then it is one period. This value uses a multiple of the plan period. For example, if the plan period is 2 weeks, then a value of 3 means the rollover balance is valid for 6 weeks. |
rolloverAllowance - Float
|
The maximum allowance that is rolled over per period. If rollover is set but this value isn't, then it is unlimited. |
rolloverMaxAllowance - Float
|
The maximum allowance that is rolled over for all periods specified by maxRolloverPeriods. If the overall rollover balance is larger then it will be removed from balances in the same order as chargeNewBalanceFirst is set. |
chargeNewBalanceFirst - Boolean
|
Determines if the newest balance or the oldest balance is charged first. False By default which means the oldest balance is charged first. |
Example
{
"managedBalanceTypeId": "4",
"periodAllowance": 123.45,
"rollover": true,
"maxRolloverPeriods": 987,
"rolloverAllowance": 123.45,
"rolloverMaxAllowance": 987.65,
"chargeNewBalanceFirst": true
}
ManagedBalanceInput
Description
Input type for the managed balance.
Fields
| Input Field | Description |
|---|---|
managedBalanceTypeId - ID!
|
The balance type ID that the plan service manages. Managing means that for this balance type ID, the service creates balances on subscription and renewal and handles rollover if specified. BalanceTypeIds must be provided if this is set and the referred balance type ID must be provided in balanceTypeIds. For fair usage and unlimited plans, a balance type counter should be added to the specified balance type ID. |
periodAllowance - Float
|
Value that the managed balance type ID will be created with. Must be an integer for unit-based balance types (no decimals allowed). Can only be a decimal value for rate based balance types. Mandatory for unit plan services - must be provided and must be greater than zero when managedBalance is used in UnitPlanServiceInput. For template-based plans, if not specified or zero it means that it is unlimited. For fair usage and unlimited plans, a balance type counter should be added to the specified balance type ID. |
rollover - Boolean
|
An action to perform with balances from a previous period. Rollover if true or reset if false. False by default. |
maxRolloverPeriods - Int
|
The maximum number of periods a rollover is maintained. If rollover is set but this value isn't, then it is one period. This value uses a multiple of the plan period. For example, if the plan period is 2 weeks, then a value of 3 means the rollover balance is valid for 6 weeks. |
rolloverAllowance - Float
|
The maximum allowance that is rolled over per period. If rollover is set but this value isn't, then it is unlimited. |
rolloverMaxAllowance - Float
|
The maximum allowance that is rolled over for all periods specified by maxRolloverPeriods. If the overall rollover balance is larger then it will be removed from balances in the same order as chargeNewBalanceFirst is set. |
chargeNewBalanceFirst - Boolean
|
Determines if the newest balance or the oldest balance is charged first. False By default which means the oldest balance is charged first. |
Example
{
"managedBalanceTypeId": 4,
"periodAllowance": 123.45,
"rollover": true,
"maxRolloverPeriods": 987,
"rolloverAllowance": 123.45,
"rolloverMaxAllowance": 987.65,
"chargeNewBalanceFirst": false
}
MigrationAlreadyInProgress
Description
An error type to be thrown if there is already migration in progress for this plan.
Example
{
"providerId": 4,
"planVersionId": 4,
"errorCode": "abc123",
"errorMessage": "xyz789"
}
MigrationType
Description
The possible values of migrating to a new plan alias.
Values
| Enum Value | Description |
|---|---|
|
|
Migrating on a specific timestamp. |
Example
"TIME"
ModelMutation
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
Example
"create"
ModelMutationMap
ModelOperation
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
Example
"create"
ModelQuery
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
Example
"get"
ModelQueryMap
ModelSubscriptionLevel
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
Example
"off"
ModelSubscriptionMap
Fields
| Input Field | Description |
|---|---|
onCreate - [String]
|
|
onUpdate - [String]
|
|
onDelete - [String]
|
|
level - ModelSubscriptionLevel
|
Example
{
"onCreate": ["abc123"],
"onUpdate": ["xyz789"],
"onDelete": ["abc123"],
"level": "off"
}
Node
OrderDirection
Description
Possible directions in which to order a list of items when provided an orderBy argument.
Values
| Enum Value | Description |
|---|---|
|
|
Specifies an ascending order for a given orderBy argument. |
|
|
Specifies a descending order for a given orderBy argument. |
Example
"ASC"
Origination
Fields
| Field Name | Description |
|---|---|
aNumberCurrentCountryExpr - String
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) Only |
bNumberHomeCountryExpr - String!
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) |
currentOperatorExpr - String
|
An MCC/MNC expression that allows for wildcards, conjunction, and negation and identifies the operator network. For example, specifying: 505/* - All of Australia and its territories. 31*/* - All of the US. 310/(350,012) - Two specific Verizon networks in the US. This uses an OR. {31*, !310/(350,012)} - All of the US except two specific Verizon networks. This is an outer AND and an inner OR. Only |
Example
{
"aNumberCurrentCountryExpr": "abc123",
"bNumberHomeCountryExpr": "abc123",
"currentOperatorExpr": "xyz789"
}
OriginationInput
Description
Information about A and B parties for MO calls.
Fields
| Input Field | Description |
|---|---|
aNumberCurrentCountryExpr - String
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) Only |
bNumberHomeCountryExpr - String!
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) |
currentOperatorExpr - String
|
An MCC/MNC expression that allows for wildcards, conjunction, and negation and identifies the operator network. For example, specifying: 505/* - All of Australia and its territories. 31*/* - All of the US. 310/(350,012) - Two specific Verizon networks in the US. This uses an OR. {31*, !310/(350,012)} - All of the US except two specific Verizon networks. This is an outer AND and an inner OR. Only currentOperatorExpr or aNumberCurrentCountryExpr can be specified but not both, they are exclusive. |
Example
{
"aNumberCurrentCountryExpr": "abc123",
"bNumberHomeCountryExpr": "abc123",
"currentOperatorExpr": "abc123"
}
PageInfo
Description
Information about pagination in a connection.
Fields
| Field Name | Description |
|---|---|
hasPreviousPage - Boolean!
|
When paginating backwards, are there more items? |
hasNextPage - Boolean!
|
When paginating forwards, are there more items? |
startCursor - String
|
When paginating backwards, the cursor to continue. |
endCursor - String
|
When paginating forwards, the cursor to continue. |
Example
{
"hasPreviousPage": false,
"hasNextPage": false,
"startCursor": "xyz789",
"endCursor": "abc123"
}
PeriodType
Description
The possible values for recurring period.
Values
| Enum Value | Description |
|---|---|
|
|
Per hour. |
|
|
Per day. |
|
|
Per week. |
|
|
Per month. |
Example
"HOUR"
Plan
Description
An object to represent a set of plan services that contains all the information to perform charging / crediting operations.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan. |
name - String!
|
A human readable name. Not unique. |
alias - [Alias!]
|
The list of plan versions and their properties that this plan aliases. |
versions - PlanVersionConnection!
|
A list of versions of the plan. |
Arguments
|
|
Example
{
"providerId": "4",
"id": "4",
"name": "xyz789",
"alias": [Alias],
"versions": PlanVersionConnection
}
PlanAliasNotActive
Description
An error type to be thrown if a plan alias does not have an active version.
Example
{
"providerId": 4,
"planId": 4,
"errorCode": "abc123",
"errorMessage": "xyz789"
}
PlanAliasNotFound
Description
An error type to be thrown if a plan alias was not found.
Example
{
"providerId": 4,
"planId": 4,
"errorCode": "xyz789",
"errorMessage": "abc123"
}
PlanAlreadyExists
Description
An error type to be thrown if a plan with provided ID already exists.
Example
{
"planId": 4,
"errorCode": "abc123",
"errorMessage": "xyz789"
}
PlanConnection
Description
The connection type for Plan.
Fields
| Field Name | Description |
|---|---|
edges - [PlanEdge!]!
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
Example
{
"edges": [PlanEdge],
"pageInfo": PageInfo
}
PlanEdge
PlanInput
Description
Input for creating a new plan.
Fields
| Input Field | Description |
|---|---|
planId - ID
|
A unique identifier of a plan. Generated if not provided. |
name - String!
|
The plan name. |
planVersion - PlanVersionInput!
|
The definition of the first plan version in this plan. |
Example
{
"planId": 4,
"name": "abc123",
"planVersion": PlanVersionInput
}
PlanIsReadOnly
Description
An error type to be thrown if the plan is the initial one preventing it from deletion.
Example
{
"providerId": 4,
"planId": 4,
"errorCode": "abc123",
"errorMessage": "abc123"
}
PlanNotFound
Description
An error type to be thrown if a plan was not found.
Example
{
"providerId": 4,
"planId": "4",
"errorCode": "xyz789",
"errorMessage": "abc123"
}
PlanOrder
Description
Ways in which lists of plans can be ordered upon return.
Fields
| Input Field | Description |
|---|---|
direction - OrderDirection!
|
The direction in which to order issues by the specified field. |
field - PlanOrderField!
|
The field in which to order plans by. |
Example
{"direction": "ASC", "field": "PRIORITY"}
PlanOrderField
Description
Properties by which plan connections can be ordered.
Values
| Enum Value | Description |
|---|---|
|
|
Order plans by last deployed plan version priority. |
|
|
Order plans by the plan name. |
|
|
Order plans by last deployed plan version state. |
|
|
Order plans by last deployed plan version modification date. |
|
|
Order plans by the number of subscribers. The number of subscribers per plan is the sum of subscribers across available and suspended plan versions of this plan. The number of subscribers per plan is updated every full hour UTC. |
|
|
Order plans by last deployed plan version purchase fee. |
|
|
Order plans by last deployed plan version renewal fee. |
Example
"PRIORITY"
PlanPayload
Description
Return type of Create / Update Plan.
Fields
| Field Name | Description |
|---|---|
plan - Plan!
|
Created / Updated plan. |
Example
{"plan": Plan}
PlanResult
Description
Return type of Plan including all possible errors.
Types
| Union Types |
|---|
Example
Plan
PlanService
Description
Plan Service Definition.
This type is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan service. |
name - String!
|
The name of the plan service. |
ratingGroups - [Int!]!
|
The rating groups supported by the service. |
priority - Float
|
The priority of the service compared to others. |
restrictions - [String!]
|
Restriction expressions of the Service. All of them must evaluate to true for the service to apply. |
Possible Types
| PlanService Types |
|---|
Example
{
"providerId": "4",
"id": "4",
"name": "abc123",
"ratingGroups": [987],
"priority": 987.65,
"restrictions": ["xyz789"]
}
PlanServiceInput
Description
Input to define the plan service.
Fields
| Input Field | Description |
|---|---|
unlimited - UnlimitedPlanServiceInput
|
Defines an unlimited plan service. |
rate - RatePlanServiceInput
|
Defines a rate plan service charging against the default monetary balance. |
unit - UnitPlanServiceInput
|
Defines a unit plan service with allowances and rollover. |
Example
{
"unlimited": UnlimitedPlanServiceInput,
"rate": RatePlanServiceInput,
"unit": UnitPlanServiceInput
}
PlanServiceValidationFailed
Description
An error type to be thrown if the PlanService cannot be created out of the provided input.
RateBalanceNotAllowedInUnlimitedService- UnlimitedPlanService cannot use rate balance type.
Example
{
"errorCode": "xyz789",
"errorMessage": "abc123"
}
PlanState
Description
Possible states of a planVersion.
Values
| Enum Value | Description |
|---|---|
|
|
A planVersion was just created and currently editable. |
|
|
A planVersion was already deployed and is no longer editable, but cannot be assigned to an Account. |
|
|
A planVersion can be assigned to an Account. |
|
|
A planVersion cannot be assigned to an Account. |
|
|
A planVersion is no longer used by any Accounts. |
Example
"NEW"
PlanVersion
Description
Versioned part of the planVersion.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan version. |
version - String!
|
String representation of the version. |
basedOn - PlanVersion
|
If the current version is based on another version. |
plan - Plan!
|
Plan of the plan version. |
state - PlanState!
|
Each version has its own state. |
refCount - Int!
|
The number of assignments to Accounts this version has. |
createdAt - AWSDateTime!
|
When it was created. |
createdBy - String!
|
By whom it was created. |
modifiedAt - AWSDateTime!
|
When it was last modified. |
modifiedBy - String!
|
By whom it was modified. |
deployedAt - AWSDateTime
|
When it was deployed. |
deployedBy - String
|
By whom it was deployed. |
template - TemplateInstance
|
If the plan version was created by using template this attribute contains all the parameters with which it was created. |
counters - [Counter]
|
List of counters defined in the plan. |
priority - Float
|
Plan version priority that determines the execution order for charging and rating. |
policies - [Policy!]
|
PCF policies associated with this plan version. |
Example
{
"providerId": "4",
"id": "4",
"version": "abc123",
"basedOn": PlanVersion,
"plan": Plan,
"state": "NEW",
"refCount": 987,
"createdAt": AWSDateTime,
"createdBy": "abc123",
"modifiedAt": AWSDateTime,
"modifiedBy": "xyz789",
"deployedAt": AWSDateTime,
"deployedBy": "xyz789",
"template": InitialTemplateInstance,
"counters": [Counter],
"priority": 987.65,
"policies": [Policy]
}
PlanVersionAlreadyExists
Description
An error type to be thrown if a plan version already exists in a plan.
Fields
| Field Name | Description |
|---|---|
plan - Plan!
|
A plan where the version already exists. |
planVersion - PlanVersionInterface!
|
Already existing plan version. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"plan": Plan,
"planVersion": PlanVersionInterface,
"errorCode": "xyz789",
"errorMessage": "abc123"
}
PlanVersionConnection
Description
The connection type for PlanVersion.
Fields
| Field Name | Description |
|---|---|
edges - [PlanVersionEdge!]!
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
Example
{
"edges": [PlanVersionEdge],
"pageInfo": PageInfo
}
PlanVersionEdge
Description
An edge in a connection.
Fields
| Field Name | Description |
|---|---|
node - PlanVersionInterface!
|
The item at the end of the edge. |
cursor - String!
|
A cursor for use in pagination. |
Example
{
"node": PlanVersionInterface,
"cursor": "xyz789"
}
PlanVersionHasReferences
Description
An error type to be thrown if a plan version has references preventing it from deletion.
Fields
| Field Name | Description |
|---|---|
planVersion - PlanVersionInterface!
|
A plan version with has references preventing it from deletion. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"planVersion": PlanVersionInterface,
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
PlanVersionInput
Description
Input to define a plan version.
Fields
| Input Field | Description |
|---|---|
simple - SimplePlanVersionInput
|
Provide 'simple' if this will be a non-recurring one-time plan. |
recurring - RecurringPlanVersionInput
|
Provide 'recurring' if this will be a recurring plan. |
Example
{
"simple": SimplePlanVersionInput,
"recurring": RecurringPlanVersionInput
}
PlanVersionInterface
Description
Versioned part of the planVersion.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan version. |
version - String!
|
String representation of the version. |
basedOn - PlanVersion
|
If the current version is based on another version. |
plan - Plan!
|
Plan of the plan version. |
state - PlanState!
|
Each version has its own state. |
refCount - Int!
|
The number of assignments to Accounts this version has. |
createdAt - AWSDateTime!
|
When it was created. |
createdBy - String!
|
By whom it was created. |
modifiedAt - AWSDateTime!
|
When it was last modified. |
modifiedBy - String!
|
By whom it was modified. |
deployedAt - AWSDateTime
|
When it was deployed. |
deployedBy - String
|
By whom it was deployed. |
template - TemplateInstance
|
If the plan version was created by using template this attribute contains all the parameters with which it was created. |
counters - [Counter]
|
List of counters defined in the plan. |
priority - Float
|
Plan version priority that determines the execution order for charging and rating. |
policies - [Policy!]
|
PCF policies associated with this plan version. |
Possible Types
| PlanVersionInterface Types |
|---|
Example
{
"providerId": 4,
"id": "4",
"version": "abc123",
"basedOn": PlanVersion,
"plan": Plan,
"state": "NEW",
"refCount": 987,
"createdAt": AWSDateTime,
"createdBy": "xyz789",
"modifiedAt": AWSDateTime,
"modifiedBy": "abc123",
"deployedAt": AWSDateTime,
"deployedBy": "abc123",
"template": InitialTemplateInstance,
"counters": [Counter],
"priority": 123.45,
"policies": [Policy]
}
PlanVersionIsNotAssignable
Description
An error type to be thrown if a plan cannot be assigned.
Example
{
"providerId": "4",
"planVersionId": "4",
"errorCode": "abc123",
"errorMessage": "abc123"
}
PlanVersionIsReadOnly
Description
An error type to be thrown if a plan version is read only. For example, when the version is already deployed.
Fields
| Field Name | Description |
|---|---|
planVersion - PlanVersionInterface!
|
A plan version which is read only. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"planVersion": PlanVersionInterface,
"errorCode": "xyz789",
"errorMessage": "abc123"
}
PlanVersionNotFound
Description
An error type to be thrown if a plan was not found.
Example
{
"providerId": 4,
"planVersionId": "4",
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
PlanVersionOrder
Description
Ways in which lists of plan versions can be ordered upon return.
Fields
| Input Field | Description |
|---|---|
direction - OrderDirection!
|
The direction in which to order issues by the specified field. |
field - PlanVersionOrderField!
|
The field in which to order versions by. |
Example
{"direction": "ASC", "field": "ID"}
PlanVersionOrderField
Description
Properties by which version connections can be ordered.
Values
| Enum Value | Description |
|---|---|
|
|
Order versions by id. |
|
|
Order versions by update time. |
|
|
Order versions by deploy time. |
Example
"ID"
PlanVersionPayload
Description
Return type of PlanVersion.
Fields
| Field Name | Description |
|---|---|
planVersion - PlanVersionInterface!
|
Created plan version. |
Example
{"planVersion": PlanVersionInterface}
PlanVersionResult
Description
Return type of PlanVersion including all possible errors.
Example
PlanVersion
PlanVersionUpdateAlreadyInProgress
Description
An error type to be the plan version update is in progress.
Example
{
"providerId": 4,
"planVersionId": 4,
"errorCode": "abc123",
"errorMessage": "abc123"
}
PlanVersionWrongTransition
Description
An error type to be thrown if transition from one state to another is not possible.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A plan version for a provided provider ID cannot be transitioned. |
planVersionId - ID!
|
A plan version with a provided plan version ID cannot be transitioned. |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"providerId": "4",
"planVersionId": "4",
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
Policy
Description
PCF policy configuration. Policies define rules and QoS profiles to apply based on conditions.
Fields
| Field Name | Description |
|---|---|
name - String
|
Descriptive name for the policy |
apply - [String!]
|
List of expressions that must all evaluate to true for this policy to apply |
ruleNames - [String!]
|
List of rule names to apply when this policy is active |
qos - ID
|
ID of the QoS profile to apply when this policy is active |
Example
{
"name": "xyz789",
"apply": ["xyz789"],
"ruleNames": ["abc123"],
"qos": 4
}
PolicyInput
Description
Input for PCF policy configuration. Policies define rules and QoS profiles to apply based on conditions.
Fields
| Input Field | Description |
|---|---|
name - String
|
Descriptive name for the policy |
apply - [String!]
|
List of expressions that must all evaluate to true for this policy to apply. If null or empty, policy always applies. |
ruleNames - [String!]
|
List of rule names to apply when this policy is active |
qos - ID
|
ID of the QoS profile to apply when this policy is active |
Example
{
"name": "xyz789",
"apply": ["abc123"],
"ruleNames": ["abc123"],
"qos": "4"
}
PostpaidFieldInPrepaidAccount
Description
An error type to be thrown when creating account if postpaid properties were not set when creditLimit of account is positive.
Example
{
"errorCode": "abc123",
"errorMessage": "xyz789"
}
PostpaidPropertiesRequired
Description
An error type to be thrown when creating account if postpaid properties were not set when creditLimit of account is positive.
Example
{
"errorCode": "xyz789",
"errorMessage": "abc123"
}
PredictionsActions
Values
| Enum Value | Description |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
Example
"identifyText"
PreemptionCapability
Description
Enumeration for ARP preemption capability.
Values
| Enum Value | Description |
|---|---|
|
|
The service cannot preempt other services |
|
|
The service may preempt other services |
Example
"NOT_PREEMPT"
PreemptionVulnerability
Description
Enumeration for ARP preemption vulnerability.
Values
| Enum Value | Description |
|---|---|
|
|
The service cannot be preempted by other services |
|
|
The service can be preempted by other services |
Example
"NOT_PREEMPTABLE"
ProfilePhoto
ProratingOptions
Description
The prorating options for a plan for postpaid accounts
Fields
| Field Name | Description |
|---|---|
alignToBillingDoM - Boolean
|
Whether to align the plan billing to the account billing day of month. If true, then subscription offer and refund policies must be filled, |
subscriptionPolicy - SubscriptionPolicy
|
The subscription policy for plans that align billing to the account billing day of month. Default is NONE. |
refundPolicy - RefundPolicy
|
The refund policy for plans that align billing to the account billing day of month. Default is NONE. |
Example
{
"alignToBillingDoM": true,
"subscriptionPolicy": "NONE",
"refundPolicy": "NONE"
}
ProratingOptionsInput
Description
Input for the prorating options for a plan for postpaid accounts
Fields
| Input Field | Description |
|---|---|
alignToBillingDoM - Boolean
|
Whether to align the plan billing to the account billing day of month. If false, then subscription and refund policies should always be NONE |
subscriptionPolicy - SubscriptionPolicy
|
The subscription policy for plans that align billing to the account billing day of month. Default is NONE. |
refundPolicy - RefundPolicy
|
The refund policy for plans that align billing to the account billing day of month. Default is NONE. |
Example
{
"alignToBillingDoM": true,
"subscriptionPolicy": "NONE",
"refundPolicy": "NONE"
}
ProviderConfig
Description
Configurations of a tenant.
Fields
| Field Name | Description |
|---|---|
id - ID!
|
The ID of the tenant. |
name - String!
|
The name of the tenant. |
commonName - String!
|
The common name that will be used in the SSL certificates of the tenant. |
homeNetworks - String
|
The home networks for the tenant. Required if onNet calls should be supported. |
emergencyNumbers - [String]
|
List of emergency numbers. |
lifecycleStage - ProviderLifecycleStage!
|
The lifecycle stage of the tenant |
allowedLifecycleTransitions - [ProviderLifecycleStage!]!
|
The allowed lifecycle transitions for the tenant. |
limits - [ApiLimitsConfig]
|
API limit configurations for 4G, 5G and GraphQL calls. |
churnFeatureEnabled - Boolean
|
Whether account churn calculation feature is enabled or not. |
frequencyOfModelUpdate - Int
|
The frequency of which the ML model is updated in days. |
frequencyOfChurnCalculation - Int
|
The frequency of calculating the accounts churn in days. |
lookbackPeriod - Int
|
The number of weeks to use for look-back data. |
deleteProviderExecutionArn - String
|
The execution ARN of delete provider operation. Empty if deletion is not in progress |
eventBusArn - String
|
The ARN of the event bus that we should be sending events to. |
parent - ID
|
The parent of this tenant. |
subtenants - [ID]
|
The list of all subtenants of a provider. |
vpcEndpointsIds - [String]
|
The list of approved VPC Endpoints IDs to be used by provider to communicate with Diameter Adapter by using non-TLS connection. |
activeAlarms - [TenantAlarmType]
|
The tenant specific alarms the provider is subscribed to. |
deviceIdSelector - DeviceIdSelector
|
The field to select device ID. Can be either 'servedGpsi' or 'subscriberIdentifier'. For the spending limit API, it uses 'gpsi' if 'servedGpsi' is used or 'supi' if 'subscriberIdentifier' is used. The default value is 'subscriberIdentifier'. |
campaignManagementEnabled - Boolean
|
Whether campaign management feature is enabled or not. This feature is not available anymore and the field will be removed. Deprecated date is 2025-06-21. Expiration date is 2025-09-21. |
failureHandling - FailureHandling
|
Failure handling strategy. Default is RETRY_AND_TERMINATE. |
rarEnabled - Boolean
|
Whether RAR notifications are enabled or not. Defaults to false. |
createAlarm - Boolean
|
Whether alarm is created for the tenant or not. Defaults to false. |
exportEnabled - Boolean
|
Incremental DB exports enabled. |
exportConfig - ExportConfig
|
Configuration for data export |
dashboardFeatureEnabled - Boolean
|
Are dashboards enabled for this tenant |
insufficientBalanceSessionHandling - InsufficientBalanceSessionHandling!
|
Insufficient balance handling strategy for session-based charging. Defaults to PROVIDE_ROUNDED_AMOUNT. Rate Anything requests with PROVIDE_ROUNDED_AMOUNT will be handled just like PROVIDE_REMAINING. |
insufficientBalanceEventHandling - InsufficientBalanceEventHandling!
|
Insufficient balance handling strategy for event-based charging. Defaults to PROVIDE_ROUNDED_AMOUNT. Rate Anything requests with PROVIDE_ROUNDED_AMOUNT will be handled just like REJECT. |
Example
{
"id": 4,
"name": "xyz789",
"commonName": "abc123",
"homeNetworks": "xyz789",
"emergencyNumbers": ["xyz789"],
"lifecycleStage": "CREATING",
"allowedLifecycleTransitions": ["CREATING"],
"limits": [ApiLimitsConfig],
"churnFeatureEnabled": true,
"frequencyOfModelUpdate": 987,
"frequencyOfChurnCalculation": 123,
"lookbackPeriod": 123,
"deleteProviderExecutionArn": "abc123",
"eventBusArn": "xyz789",
"parent": 4,
"subtenants": ["4"],
"vpcEndpointsIds": ["abc123"],
"activeAlarms": ["ACCOUNT_NOT_FOUND"],
"deviceIdSelector": "SERVED_GPSI",
"campaignManagementEnabled": false,
"failureHandling": "TERMINATE",
"rarEnabled": false,
"createAlarm": true,
"exportEnabled": false,
"exportConfig": ExportConfig,
"dashboardFeatureEnabled": true,
"insufficientBalanceSessionHandling": "IGNORE",
"insufficientBalanceEventHandling": "REJECT"
}
ProviderLifecycleStage
Description
Providers possible Lifecycle stages
Values
| Enum Value | Description |
|---|---|
|
|
Provider is in the process of being created but cannot be used for any live operations / traffic. |
|
|
Provider has reference data (plan, accounts devices) loaded, is connected to receive charging events and is ready for User Acceptance Testing. |
|
|
Provider is fully operational. |
|
|
Provider is suspended and no usage of the system is possible. Requests via any API will be rejected with an error code indicating the suspended state. |
|
|
Provider is fully terminated. No data is deleted from the system. |
|
|
All customer data, except for EDRs, is removed from the system with the exception of any data that must be maintained / archived for regulatory reasons. Customers may also ask for 'proof' of data destruction. |
Example
"CREATING"
ProviderNotFound
Description
An error type to be thrown if tenant was not found for given ID.
Example
{
"providerId": "4",
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
QoS
Description
Quality of Service parameters.
Fields
| Field Name | Description |
|---|---|
allowed5QI - [Int!]!
|
List of allowed 5QI values |
minArpPriorityLevel - Int!
|
Minimum ARP priority level (1-15) |
arpPreemptionCapability - PreemptionCapability!
|
ARP preemption capability |
arpPreemptionVulnerability - PreemptionVulnerability!
|
ARP preemption vulnerability |
min5QIPriorityLevel - Int
|
Minimum 5QI priority level |
averagingWindow - Int
|
Averaging window in milliseconds |
maxDataBurstVol - Int
|
Maximum data burst volume in bytes |
maxBitRateUL - String
|
Maximum uplink bit rate |
maxBitRateDL - String
|
Maximum downlink bit rate |
maxGuaranteedBitRateUL - String
|
Maximum guaranteed uplink bit rate |
maxGuaranteedBitRateDL - String
|
Maximum guaranteed downlink bit rate |
extMaxDataBurstVol - Int
|
Extended maximum data burst volume in bytes |
Example
{
"allowed5QI": [987],
"minArpPriorityLevel": 987,
"arpPreemptionCapability": "NOT_PREEMPT",
"arpPreemptionVulnerability": "NOT_PREEMPTABLE",
"min5QIPriorityLevel": 987,
"averagingWindow": 123,
"maxDataBurstVol": 123,
"maxBitRateUL": "abc123",
"maxBitRateDL": "xyz789",
"maxGuaranteedBitRateUL": "abc123",
"maxGuaranteedBitRateDL": "abc123",
"extMaxDataBurstVol": 123
}
QoSInput
Description
Input for Quality of Service parameters.
Fields
| Input Field | Description |
|---|---|
allowed5QI - [Int!]!
|
List of allowed 5QI values |
minArpPriorityLevel - Int!
|
Minimum ARP priority level (1-15) |
arpPreemptionCapability - PreemptionCapability!
|
ARP preemption capability |
arpPreemptionVulnerability - PreemptionVulnerability!
|
ARP preemption vulnerability |
min5QIPriorityLevel - Int
|
Minimum 5QI priority level |
averagingWindow - Int
|
Averaging window in milliseconds |
maxDataBurstVol - Int
|
Maximum data burst volume in bytes |
maxBitRateUL - String
|
Maximum uplink bit rate (format: ' |
maxBitRateDL - String
|
Maximum downlink bit rate (format: ' |
maxGuaranteedBitRateUL - String
|
Maximum guaranteed uplink bit rate (format: ' |
maxGuaranteedBitRateDL - String
|
Maximum guaranteed downlink bit rate (format: ' |
extMaxDataBurstVol - Int
|
Extended maximum data burst volume in bytes |
Example
{
"allowed5QI": [123],
"minArpPriorityLevel": 123,
"arpPreemptionCapability": "NOT_PREEMPT",
"arpPreemptionVulnerability": "NOT_PREEMPTABLE",
"min5QIPriorityLevel": 123,
"averagingWindow": 987,
"maxDataBurstVol": 123,
"maxBitRateUL": "abc123",
"maxBitRateDL": "abc123",
"maxGuaranteedBitRateUL": "abc123",
"maxGuaranteedBitRateDL": "xyz789",
"extMaxDataBurstVol": 123
}
QoSProfile
Description
QoS Profile for PCF policy negotiation.
Fields
| Field Name | Description |
|---|---|
id - ID!
|
The unique identifier of the QoS profile |
providerId - ID!
|
The provider ID this profile belongs to |
name - String!
|
A descriptive name for the QoS profile |
priority - Int!
|
Priority for selecting this profile when multiple profiles are applicable (lower value = higher priority) |
qos - QoS
|
Quality of Service parameters |
ambr - Ambr
|
Aggregate Maximum Bit Rate parameters |
createdAt - String!
|
The timestamp when the profile was created |
modifiedAt - String!
|
The timestamp when the profile was last modified |
Example
{
"id": 4,
"providerId": "4",
"name": "abc123",
"priority": 987,
"qos": QoS,
"ambr": Ambr,
"createdAt": "xyz789",
"modifiedAt": "xyz789"
}
QoSProfileConnection
Description
The connection type for QoSProfile.
Fields
| Field Name | Description |
|---|---|
edges - [QoSProfileEdge!]!
|
List of nodes in the connection. |
pageInfo - PageInfo!
|
Information about pagination in the connection. |
Example
{
"edges": [QoSProfileEdge],
"pageInfo": PageInfo
}
QoSProfileEdge
Description
An edge in a connection.
Fields
| Field Name | Description |
|---|---|
node - QoSProfile!
|
The item at the end of the edge. |
cursor - String!
|
A cursor for use in pagination. |
Example
{
"node": QoSProfile,
"cursor": "abc123"
}
QoSProfileInUse
Description
Error type for when a QoS Profile is still in use and cannot be deleted.
Example
{
"providerId": "4",
"qosProfileId": 4,
"referencingPlanVersions": [4],
"errorCode": "abc123",
"errorMessage": "abc123"
}
QoSProfileInput
Description
Input for QoS Profile creation and update.
Fields
| Input Field | Description |
|---|---|
name - String!
|
A descriptive name for the QoS profile |
priority - Int!
|
Priority for selecting this profile when multiple profiles are applicable (lower value = higher priority) |
qos - QoSInput
|
Quality of Service parameters |
ambr - AmbrInput
|
Aggregate Maximum Bit Rate parameters |
Example
{
"name": "abc123",
"priority": 987,
"qos": QoSInput,
"ambr": AmbrInput
}
QoSProfileNotFound
Description
Error type for when a QoS Profile is not found.
Example
{
"providerId": 4,
"qosProfileId": "4",
"errorCode": "abc123",
"errorMessage": "abc123"
}
RarNotEnabled
Description
An error type to be thrown when RAR is triggered for a provider with disabled RAR feature.
Example
{
"providerId": 4,
"errorCode": "xyz789",
"errorMessage": "abc123"
}
Rate
Description
Rate configuration.
Fields
| Field Name | Description |
|---|---|
ratePerRounding - String
|
Particular rate in unit rounding to be applied. |
taxRate - Float!
|
A tax rate to be applied. It is a percentage and expressed as a fraction. For example, 0.15 stands for 15% tax rate. |
rateMinUnits - Int
|
Minimum number of rounding units to charge. To determine the total minimum units, the value specified is multiplied by perUnitRounding defined for the rating group. If not specified, it defaults to 0. |
initialCharge - String
|
The initial monetary charge/flag fall fee if premium numbers are specified. If not specified, it will default to 0. |
Example
{
"ratePerRounding": "xyz789",
"taxRate": 987.65,
"rateMinUnits": 123,
"initialCharge": "abc123"
}
RateBalance
Description
Rate configuration for monetary balance.
Fields
| Field Name | Description |
|---|---|
rate - Rate
|
Rate configuration. If not specified then monetary usage is denied (except roaming and long distance which are configured independently). |
roaming - [ExtendedRate!]
|
Roaming configuration. If not specified then roaming will be denied. |
longDistance - [ExtendedRate!]
|
Long distance configuration. If not specified then long distance will be denied. |
Example
{
"rate": Rate,
"roaming": [ExtendedRate],
"longDistance": [ExtendedRate]
}
RateBalanceInput
Description
Input type for rate based balances.
Fields
| Input Field | Description |
|---|---|
rate - RateInput
|
Rate configuration. If not specified then monetary usage is denied (except roaming and long distance which are configured independently). |
roaming - [ExtendedRateInput!]
|
Roaming configuration. If not specified then roaming will be denied. |
longDistance - [ExtendedRateInput!]
|
Long distance configuration. If not specified then long distance will be denied. |
Example
{
"rate": RateInput,
"roaming": [ExtendedRateInput],
"longDistance": [ExtendedRateInput]
}
RateInput
Description
Rate configuration.
Fields
| Input Field | Description |
|---|---|
ratePerRounding - String
|
Particular rate in unit rounding to be applied. |
taxRate - Float!
|
A tax rate to be applied. It is a percentage and expressed as a fraction. For example, 0.15 stands for 15% tax rate. |
rateMinUnits - Int
|
Minimum number of rounding units to charge. To determine the total minimum units, the value specified is multiplied by perUnitRounding defined for the rating group. If not specified, it defaults to 0. |
initialCharge - String
|
The initial monetary charge/flag fall fee if premium numbers are specified. If not specified, it will default to 0. |
Example
{
"ratePerRounding": "abc123",
"taxRate": 987.65,
"rateMinUnits": 987,
"initialCharge": "abc123"
}
RateLimitExceeded
Description
An error type to be thrown if a provider crossed the rate limit and request will be rejected
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Service provider ID with problem. |
retryAfter - AWSDateTime!
|
Date when the rate limit should be restored and request should be retried |
errorCode - String!
|
The error code in question. |
errorMessage - String
|
The error message in question. |
Example
{
"providerId": 4,
"retryAfter": AWSDateTime,
"errorCode": "xyz789",
"errorMessage": "abc123"
}
RateOption
Description
Rate configuration.
Fields
| Field Name | Description |
|---|---|
ratePerRounding - String!
|
Particular rate in unit rounding to be applied. |
taxRate - String
|
A tax rate to be applied. It is a percentage and expressed as a fraction. For example, 0.15 stands for 15% tax rate. |
rateMinUnits - Int
|
Minimum number of units to use when premium numbers are specified. Numbers specified are a multiple of perUnitRounding defined in the rating group hierarchy for that rating group. If not specified, it will default to 0. |
initialCharge - String
|
The initial monetary charge/flag fall fee if premium numbers are specified. If not specified, it will default to 0. |
restrictions - [String!]
|
Restriction expressions of the Rate. All of them must evaluate to true for the rate to apply. |
Example
{
"ratePerRounding": "abc123",
"taxRate": "abc123",
"rateMinUnits": 123,
"initialCharge": "xyz789",
"restrictions": ["abc123"]
}
RateOptionInput
Description
Rate configuration.
Fields
| Input Field | Description |
|---|---|
ratePerRounding - String!
|
Particular rate in unit rounding to be applied. |
taxRate - String
|
A tax rate to be applied. It is a percentage and expressed as a fraction. For example, 0.15 stands for 15% tax rate. |
rateMinUnits - Int
|
Minimum number of units to use when premium numbers are specified. Numbers specified are a multiple of perUnitRounding defined in the rating group hierarchy for that rating group. If not specified, it will default to 0. |
initialCharge - String
|
The initial monetary charge/flag fall fee if premium numbers are specified. If not specified, it will default to 0. |
restrictions - [String!]
|
Restriction expressions of the Rate. All of them must evaluate to true for the rate to apply. |
Example
{
"ratePerRounding": "abc123",
"taxRate": "abc123",
"rateMinUnits": 123,
"initialCharge": "abc123",
"restrictions": ["abc123"]
}
RatePlanService
Description
Type definition for a rate plan service.
This type is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan service. |
name - String!
|
The name of the plan service. |
ratingGroups - [Int!]!
|
The rating groups supported by the service. |
priority - Float
|
The priority of the service compared to others. |
restrictions - [String!]
|
Restriction expressions of the Service. All of them must evaluate to true for the service to apply. |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. |
rateOptions - [RateOption!]
|
Rate configurations. If not specified then monetary usage is denied. |
Example
{
"providerId": 4,
"id": "4",
"name": "xyz789",
"ratingGroups": [123],
"priority": 987.65,
"restrictions": ["xyz789"],
"denyOtherServices": true,
"rateOptions": [RateOption]
}
RatePlanServiceInput
Description
Input to define a rate plan service.
Fields
| Input Field | Description |
|---|---|
name - String
|
Name of the plan service. Generated if not provided. |
ratingGroups - [Int!]!
|
The rating groups supported by the service. |
priority - Float
|
Defines the priority of the service compared to others. |
restrictions - [String!]
|
Restriction expressions of the Service. All of them must evaluate to true for the service to apply. |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. By default it is false. |
rateOptions - [RateOptionInput!]
|
Rate configuration. If not specified then monetary usage is denied. |
Example
{
"name": "xyz789",
"ratingGroups": [123],
"priority": 123.45,
"restrictions": ["abc123"],
"denyOtherServices": false,
"rateOptions": [RateOptionInput]
}
RatingGroup
Description
Rating group.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - Int!
|
Rating Group ID. |
name - String!
|
Name of the rating group. |
perUnitRounding - Int
|
Unit rounding. |
minReservation - Float
|
Minimum total resevation that can be held for this rating group. If empty then there is no minimum. |
maxReservation - Float
|
Maximum total resevation that can be held for this rating group. If empty then there is no maximum. |
unitType - UnitType!
|
Unit type that is used for this rating group. |
quotaValidityTime - Int
|
Validity type which is returned in responses. |
quotaHoldingTime - Int
|
Holding time which is returned in responses. |
enableDynamicQuotaAllocation - Boolean
|
Whether dynamic quotas will be used or not. |
announcementMapping - AnnouncementMapping
|
Configuration for condition-specific announcement codes. |
isDefault - Boolean!
|
Default groups are determined by names, not by IDs, ID of default group can be changed. |
children - [RatingGroup]
|
List of nested rating groups. |
Example
{
"providerId": 4,
"id": 987,
"name": "abc123",
"perUnitRounding": 987,
"minReservation": 987.65,
"maxReservation": 987.65,
"unitType": "TIME",
"quotaValidityTime": 123,
"quotaHoldingTime": 987,
"enableDynamicQuotaAllocation": false,
"announcementMapping": AnnouncementMapping,
"isDefault": false,
"children": [RatingGroup]
}
RatingGroupHierarchyHasReferences
Description
An error type to be thrown if there is a rating group which is not provided in the input but used by some plan.
Fields
| Field Name | Description |
|---|---|
ratingGroup - [RatingGroup!]!
|
A list of rating groups that have references to plans. |
errorCode - String!
|
|
errorMessage - String
|
Example
{
"ratingGroup": [RatingGroup],
"errorCode": "abc123",
"errorMessage": "xyz789"
}
RatingGroupInput
Description
Rating group parameters.
Fields
| Input Field | Description |
|---|---|
id - Int!
|
Rating group ID. |
name - String!
|
Unique name for this Rating Group. Must be between 1 and 50 characters and consist of letters, digits or special characters. |
perUnitRounding - Int
|
Unit rounding. If not provided then unit rounding is used from parents RGs. |
minReservation - Float
|
Minimum total reservation that can be held for this rating group. If not provided then there is no minimum. |
maxReservation - Float
|
Maximum total reservation that can be held for this rating group. If not provided then there is no maximum. |
unitType - UnitType
|
Unit type that is used for this rating group. Service specific units used by default. |
quotaValidityTime - Int
|
Validity type which is returned in responses. |
quotaHoldingTime - Int
|
Holding time which is returned in responses. |
enableDynamicQuotaAllocation - Boolean
|
Whether dynamic quotas will be used or not. |
announcementMapping - AnnouncementMappingInput
|
Configuration for condition-specific announcement codes. |
children - [RatingGroupInput]
|
List of nested rating groups. |
Example
{
"id": 123,
"name": "abc123",
"perUnitRounding": 987,
"minReservation": 987.65,
"maxReservation": 987.65,
"unitType": "TIME",
"quotaValidityTime": 123,
"quotaHoldingTime": 987,
"enableDynamicQuotaAllocation": true,
"announcementMapping": AnnouncementMappingInput,
"children": [RatingGroupInput]
}
RatingGroupResult
Description
Return type of RatingGroup including all possible errors.
Types
| Union Types |
|---|
Example
RatingGroup
RatingGroupValidationFailed
Description
An error type to be thrown if rating group hierarchy validation failed.
Fields
| Field Name | Description |
|---|---|
root - RatingGroup!
|
A list of default rating groups if default rating groups were not provided. |
errorCode - String!
|
|
errorMessage - String
|
Example
{
"root": RatingGroup,
"errorCode": "abc123",
"errorMessage": "abc123"
}
RecurringPeriod
Description
Information about the plan recurring period
Fields
| Field Name | Description |
|---|---|
periodType - PeriodType!
|
Determines a period when counter value must be reset. |
numberOfPeriods - Int!
|
The number of period types that will be used to reset or expire the plan. |
recurring - Boolean!
|
Determines if the plan is recurring or expires after the period. |
Example
{"periodType": "HOUR", "numberOfPeriods": 987, "recurring": false}
RecurringPeriodInput
Description
Parameters for recurring period.
Fields
| Input Field | Description |
|---|---|
periodType - PeriodType!
|
Determines a period when counter value must be reset. |
numberOfPeriods - Int!
|
The number of period types that will be used to reset or expire the plan. |
recurring - Boolean!
|
Determines if the plan is recurring or expires after the period. |
Example
{"periodType": "HOUR", "numberOfPeriods": 123, "recurring": true}
RecurringPlanVersion
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan version. |
version - String!
|
String representation of the version. |
basedOn - PlanVersion
|
If the current version is based on another version. |
plan - Plan!
|
Plan of the plan version. |
state - PlanState!
|
Each version has its own state. |
refCount - Int!
|
The number of assignments to Accounts this version has. |
createdAt - AWSDateTime!
|
When it was created. |
createdBy - String!
|
By whom it was created. |
modifiedAt - AWSDateTime!
|
When it was last modified. |
modifiedBy - String!
|
By whom it was modified. |
deployedAt - AWSDateTime
|
When it was deployed. |
deployedBy - String
|
By whom it was deployed. |
template - TemplateInstance
|
If the plan version was created by using template this attribute contains all the parameters with which it was created. |
counters - [Counter]
|
List of counters defined in the plan. |
priority - Float
|
Plan version priority that determines the execution order for charging and rating. |
services - [PlanService!]
|
The list of plan services of the plan version. This attribute is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out. |
custom - AWSJSON
|
Any custom details. |
purchaseFee - Float
|
A fee that will be charged just once right after the subscription. If not provided, no fee is charged. |
firstUsageFee - Float
|
A fee that will be charged just once on first usage of the plan. If not provided, no fee is charged. |
renewal - Duration
|
A duration when specified renewalFee will be charged. |
renewalFee - Float
|
A fee that will be charged per specified renewal duration. Recurring fee is charged first time after the first period. If you need to charge some fee on subscription you need to use purchaseFee. If not provided then no such fee is charged. |
gracePeriod - String
|
Put a plan on hold for a limited grace period while waiting for a successful renewal. Must be a valid ISO 8601 duration string (e.g., "P1W1D", "PT30M"). |
notificationSecondsBeforeRenewal - [Int]
|
Defines the seconds before expiration to send notifications. |
policies - [Policy!]
|
PCF policies associated with this plan version. |
Example
{
"providerId": 4,
"id": "4",
"version": "abc123",
"basedOn": PlanVersion,
"plan": Plan,
"state": "NEW",
"refCount": 123,
"createdAt": AWSDateTime,
"createdBy": "abc123",
"modifiedAt": AWSDateTime,
"modifiedBy": "abc123",
"deployedAt": AWSDateTime,
"deployedBy": "abc123",
"template": InitialTemplateInstance,
"counters": [Counter],
"priority": 987.65,
"services": [PlanService],
"custom": AWSJSON,
"purchaseFee": 123.45,
"firstUsageFee": 123.45,
"renewal": Duration,
"renewalFee": 123.45,
"gracePeriod": "xyz789",
"notificationSecondsBeforeRenewal": [987],
"policies": [Policy]
}
RecurringPlanVersionInput
Description
Input to define a recurring plan.
Fields
| Input Field | Description |
|---|---|
version - String!
|
String representation of the version. |
services - [PlanServiceInput!]!
|
The services included in the plan. |
custom - AWSJSON
|
Any custom details of the plan version. |
priority - Float
|
Plan version priority. |
purchaseFee - Float
|
A fee charged once immediately after subscription. If not provided, no fee is charged. |
firstUsageFee - Float
|
A fee charged once upon the first usage of the plan. If not provided, no fee is charged. |
renewal - DurationInput!
|
A duration when specified renewalFee will be charged. |
renewalFee - Float
|
A fee that will be charged per specified renewal duration. Recurring fee is charged first time after the first period. If you need to charge some fee on subscription you need to use purchaseFee. If not provided then no such fee is charged. |
gracePeriod - String
|
Put a plan on hold for a limited grace period while waiting for a successful renewal. Must be a valid ISO 8601 duration string (e.g., "P1W1D", "PT30M"). |
notificationSecondsBeforeRenewal - [Int]
|
Defines the seconds before expiration to send notifications. |
policies - [PolicyInput!]
|
PCF policies to apply for this plan version |
Example
{
"version": "xyz789",
"services": [PlanServiceInput],
"custom": AWSJSON,
"priority": 123.45,
"purchaseFee": 987.65,
"firstUsageFee": 987.65,
"renewal": DurationInput,
"renewalFee": 123.45,
"gracePeriod": "xyz789",
"notificationSecondsBeforeRenewal": [123],
"policies": [PolicyInput]
}
RefundPolicy
Description
The possible values of prorating for the accounts on cancellation of subscriptions.
Values
| Enum Value | Description |
|---|---|
|
|
No refund for for any remaining time in the cycle. |
|
|
The recurring offer charge is refunded in full. |
|
|
The recurring offer charge is refunded relative to the point in the bill cycle that the offer was canceled. |
Example
"NONE"
ResetUserPasswordInput
ResetUserPasswordPayload
ResetUserPasswordResult
Description
Return type of ResetUserPassword including all possible errors.
UserNotFound- Given user ID does not exist in the tenant, even if user ID exists in CognitoUserIncorrectStatus- Given user is not in a state where the password can be resetInvalidField (InvalidEmailDomain)- Unable to call the API for the user in this domain
Example
ResetUserPasswordPayload
RestoreJob
Description
Type for restore job.
Fields
| Field Name | Description |
|---|---|
id - ID!
|
ID for the restore job. |
providerId - ID!
|
Provider ID. |
status - RestoreJobStatus!
|
Status of the job. |
createdAt - AWSDateTime!
|
The creation time of the job. |
createdBy - AWSEmail!
|
The email of the person who triggered the restore job. |
modifiedAt - AWSDateTime!
|
Time of the last update of the record. Will be the same as the creation date when record is created. |
timestamp - AWSDateTime!
|
Date/time in UTC to restore the data to. |
Example
{
"id": 4,
"providerId": "4",
"status": "CREATED",
"createdAt": AWSDateTime,
"createdBy": AWSEmail,
"modifiedAt": AWSDateTime,
"timestamp": AWSDateTime
}
RestoreJobStatus
Description
Status of a restore job.
Values
| Enum Value | Description |
|---|---|
|
|
Status when the job is first created. |
|
|
Status to state that the job is in progress. |
|
|
Status after job is complete. |
|
|
Status after job is canceled. |
Example
"CREATED"
RoleGroup
Description
Cognito role groups
Values
| Enum Value | Description |
|---|---|
|
|
Role to allow user to query accounts/devices |
|
|
Role to allow user to manipulate accounts/devices |
|
|
Role to allow user to query/manipulate accounts/devices and query EDRs |
|
|
Role to allow user to query plan related data |
|
|
Role to allow user to query/manipulate plan related data |
|
|
Role to allow user to query/manipulate plan related data and to publish plans |
|
|
Role to allow user to administer users of his/her own tenant |
|
|
Role to allow user to query/deploy field mappings and update rating groups of his/her own tenant |
|
|
Role to allow user to query/manipulate field mappings and SGSN table of his/her own tenant |
|
|
Role to allow user to query/manipulate plan design settings of his/her own tenant |
|
|
Allows access to engine APIs |
|
|
Role to allow user to read provider dashboards |
Example
"Account_Query"
SGSNTable
Description
Information about the SGSN table
Fields
| Field Name | Description |
|---|---|
rows - [SGSNTableItem]!
|
SGSN table rows |
Example
{"rows": [SGSNTableItem]}
SGSNTableInput
Description
Information about the SGSN table
Fields
| Input Field | Description |
|---|---|
rows - [SGSNTableItemInput]!
|
SGSN table rows |
Example
{"rows": [SGSNTableItemInput]}
SGSNTableItem
SGSNTableItemInput
SGSNTableResult
Description
Return type of getSGSNTable.
Types
| Union Types |
|---|
Example
SGSNTable
SaveUserPayload
Description
Return type of a User for mutations creating/updating
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
Service provider ID. This is retrieved from cognito group named Provider_{providerId} |
userId - ID!
|
Cognito User ID |
email - AWSEmail!
|
User email |
name - String!
|
The name of the user |
roleGroupMemberships - [RoleGroup!]!
|
The roles this user belong to |
profilePicture - ProfilePhoto
|
The user's profile picture. If profile picture exists, it will always contain a pre-signed URL to download profile picture. It will contain pre-signed URL to upload picture only for the updateUserProfile mutation |
phoneNumber - AWSPhone
|
The user's phone number |
jobTitle - String
|
The user's job title |
expiry - AWSDateTime
|
The time when the user should expire. Used for temporary access. |
alertInterval - Int
|
The alarm interval in minutes when an email should be send to the user that access expires. Only used when expiry is specified. Can be 0 or not specified when expiry is specified which means no email is send. |
Example
{
"providerId": 4,
"userId": 4,
"email": AWSEmail,
"name": "abc123",
"roleGroupMemberships": ["Account_Query"],
"profilePicture": ProfilePhoto,
"phoneNumber": AWSPhone,
"jobTitle": "xyz789",
"expiry": AWSDateTime,
"alertInterval": 123
}
SearchableQueryMap
Fields
| Input Field | Description |
|---|---|
search - String
|
Example
{"search": "abc123"}
ServiceConstraint
Description
Possible restrictions for plan service usage.
Values
| Enum Value | Description |
|---|---|
|
|
A flag indicating calls to or from friends and family. This field is deprecated in favor of custom fields. Deprecated date is 2025-02-14. Expiration date is 2025-04-13. |
|
|
A flag indicating on-net calls. On-net means that the A-number is in the home network and the B-number belongs to the same service provider. Only supported if the provider carrier code/homeNetworks is set. |
|
|
A flag indicating off-net calls. If a call is not on-net it is off-net. Only supported if the provider carrier code/homeNetworks is set. |
|
|
A flag indicating whether roaming services are only applicable if the A-number and B-number are in the same country. For example, when roaming in the US and calling a number in the US. |
Example
"IS_FRIEND_FAMILY"
ServiceFormatError
Description
An error type to be thrown if a new version of a plan is created based on the old format while a version with the new format exists.
Example
{
"providerId": "4",
"versionId": "4",
"errorCode": "xyz789",
"errorMessage": "abc123"
}
Settings
Description
Settings for providers.
Example
{
"providerId": "4",
"json": AWSJSON,
"enableDynamicQuotaTestMode": true
}
SettingsResult
Description
Return type of Settings including all possible errors.
Types
| Union Types |
|---|
Example
Settings
SimplePlanVersion
Description
Versioned part of the planVersion.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan version. |
version - String!
|
String representation of the version. |
basedOn - PlanVersion
|
If the current version is based on another version. |
plan - Plan!
|
Plan of the plan version. |
state - PlanState!
|
Each version has its own state. |
refCount - Int!
|
The number of assignments to Accounts this version has. |
createdAt - AWSDateTime!
|
When it was created. |
createdBy - String!
|
By whom it was created. |
modifiedAt - AWSDateTime!
|
When it was last modified. |
modifiedBy - String!
|
By whom it was modified. |
deployedAt - AWSDateTime
|
When it was deployed. |
deployedBy - String
|
By whom it was deployed. |
template - TemplateInstance
|
If the plan version was created by using template this attribute contains all the parameters with which it was created. |
counters - [Counter]
|
List of counters defined in the plan. |
priority - Float
|
Plan version priority that determines the execution order for charging and rating. |
services - [PlanService!]
|
The list of plan services of the plan version. This attribute is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out. |
custom - AWSJSON
|
Any custom details. |
purchaseFee - Float
|
A fee that will be charged just once right after the subscription. If not provided, no fee is charged. |
firstUsageFee - Float
|
A fee that will be charged just once on first usage of the plan. If not provided, no fee is charged. |
expiration - Duration
|
Defines the period the plan is available. |
notificationSecondsBeforeExpiration - [Int!]
|
Defines the seconds before expiration to send notifications. |
policies - [Policy!]
|
PCF policies associated with this plan version. |
Example
{
"providerId": "4",
"id": 4,
"version": "abc123",
"basedOn": PlanVersion,
"plan": Plan,
"state": "NEW",
"refCount": 987,
"createdAt": AWSDateTime,
"createdBy": "xyz789",
"modifiedAt": AWSDateTime,
"modifiedBy": "abc123",
"deployedAt": AWSDateTime,
"deployedBy": "abc123",
"template": InitialTemplateInstance,
"counters": [Counter],
"priority": 123.45,
"services": [PlanService],
"custom": AWSJSON,
"purchaseFee": 987.65,
"firstUsageFee": 123.45,
"expiration": Duration,
"notificationSecondsBeforeExpiration": [123],
"policies": [Policy]
}
SimplePlanVersionInput
Description
Input to define a simple (non-recurring) plan.
Fields
| Input Field | Description |
|---|---|
version - String!
|
String representation of the version. |
services - [PlanServiceInput!]!
|
The services included in the plan. |
custom - AWSJSON
|
Any custom details of the plan version. |
priority - Float
|
Plan version priority. |
purchaseFee - Float
|
A fee charged once immediately after subscription. If not provided, no fee is charged. |
firstUsageFee - Float
|
A fee charged once upon the first usage of the plan. If not provided, no fee is charged. |
expiration - DurationInput
|
Defines the period the plan is available. |
notificationSecondsBeforeExpiration - [Int!]
|
Defines the seconds before expiration to send notifications. |
policies - [PolicyInput!]
|
PCF policies to apply for this plan version |
Example
{
"version": "xyz789",
"services": [PlanServiceInput],
"custom": AWSJSON,
"priority": 123.45,
"purchaseFee": 123.45,
"firstUsageFee": 123.45,
"expiration": DurationInput,
"notificationSecondsBeforeExpiration": [123],
"policies": [PolicyInput]
}
String
Description
The String scalar type represents textual data, represented as UTF-8 character sequences. The String type is most often used by GraphQL to represent free-form human-readable text.
Example
"abc123"
SubscribeToPlanVersionInput
Description
Input type of SubscribeToPlanVersion.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
accountId - ID!
|
A unique identifier of an account. |
planVersionId - ID
|
Unique identifier of a plan version to subscribe to. You should provide only one of the following: Opt for |
planId - ID
|
Additional Information: If there is no active version of the plan at the time of the API call, SubscribeToPlan will raise an error even if the subscription is for a future date. The active plan version is the one with the most recent effectiveDateTime that is not in the future, and it is included in the aliases array returned by the getPlan query.
|
from - AWSDateTime
|
The start time of the subscription. Set to now if not provided. |
to - AWSDateTime
|
The end time of the subscription. If not provided, it defaults to "3000-01-01T00:00:00.000Z" to indicate an indefinite end date for recurring plans and set to start time (from) plus the plan period for non-recurring ones. |
overrides - [KeyValueInput]
|
List of fields with values that override values from a plan. |
Example
{
"providerId": 4,
"accountId": "4",
"planVersionId": 4,
"planId": 4,
"from": AWSDateTime,
"to": AWSDateTime,
"overrides": [KeyValueInput]
}
SubscribeToPlanVersionPayload
Description
Return type of SubscribeToPlanVersion.
Fields
| Field Name | Description |
|---|---|
subscribedPlanVersion - SubscribedPlanVersion!
|
The subscribed plan version in question. |
account - Account!
|
The account in question. |
Example
{
"subscribedPlanVersion": SubscribedPlanVersion,
"account": Account
}
SubscribeToPlanVersionResult
Description
Return type of SubscribeToPlan including all possible errors.
SubscribeToPlanVersionValidationFailed (SubscriptionDateCannotExceedPlanPeriod)- should be returned when the plan is non recurring and the subscription exceeds the plan period length.SubscribeToPlanVersionValidationFailed (ActiveSubscriptionFromDateIsReadOnly)- The “from” date of an active subscription cannot be changed.SubscribeToPlanVersionValidationFailed (PurchaseFeeCannotBeCharged)- There is not enough balance to charge a purchase fee, plan subscription has been expired immediately.PlanVersionNotFound (PlanVersionNotFound)- The requested plan version with the provided ID cannot be found.PlanNotFound (PlanNotFound)- The requested plan with the provided ID cannot be found.PlanAliasNotFound (PlanAliasNotFound)- The requested plan alias with the provided ID cannot be found.PlanAliasNotActive (PlanAliasNotActive)- The requested plan alias with the provided ID does not have an active version.PlanVersionIsNotAssignable (PlanVersionIsNotAssignable)- The requested plan version is marked as not assignable. Please, make it assignable first.AccountNotFound (AccountNotFound)- The requested account with the provided ID cannot be found.SubscriptionNotFound (SubscriptionNotFound)- The plan subscription with the provided ID was not found.InvalidField (OnlyOnePlanToBeProvided)- You cannot provide both planId and planVersionId.InvalidField (PlanMustBeProvided)- Either planId or planVersionId must be provided.InvalidField (InvalidFutureDate)- The provided date cannot be in the past.InvalidField (InvalidDatesRange)- The provided "to" date cannot be earlier than the provided "from" date..InternalServerError (ChargeEngineNotAvailable)- The charge engine is not available at this time.
Types
| Union Types |
|---|
Example
SubscribeToPlanVersionPayload
SubscribeToPlanVersionValidationFailed
SubscribedPlanVersion
Description
An instance of a plan version that belongs to an account.
Fields
| Field Name | Description |
|---|---|
planSubscriptionId - ID!
|
The ID of the subscription. |
from - AWSDateTime
|
The start time of the subscription. |
to - AWSDateTime
|
The end time of the subscription. |
renewal - AWSDateTime
|
The time of the next renewal of the subscription if it is a recurring plan. |
planVersion - PlanVersionInterface!
|
The plan version of the subscription. |
aliasEnabled - Boolean!
|
Whether or not this is a referenced plan version defined through the deploy API. |
overrides - [KeyValue]
|
List of fields with values that override values from a plan. |
Example
{
"planSubscriptionId": 4,
"from": AWSDateTime,
"to": AWSDateTime,
"renewal": AWSDateTime,
"planVersion": PlanVersionInterface,
"aliasEnabled": true,
"overrides": [KeyValue]
}
SubscriptionNotFound
Description
An error type to be thrown if a subscription for provided dates cannot be found. If "to" was empty in input, it will be empty in error. If "from" was empty in input, it will be "now" in error.
Example
{
"planSubscriptionId": "4",
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
SubscriptionPolicy
Description
The possible values of prorating for the postpaid accounts on subscription.
Values
| Enum Value | Description |
|---|---|
|
|
Recurring offers (charge or allowance) are applied in full, independent of when the offer is purchased related to the bill cycle date. |
|
|
Recurring offers (charge or allowance) are prorated based on when the offer is purchased relative to the bill cycle. |
Example
"NONE"
TemplateInstance
Description
A union to define all possible parameters for templates.
Types
| Union Types |
|---|
Example
InitialTemplateInstance
TenantAlarmType
Description
Type of tenant specific alarms that tenants can subscribe to.
Values
| Enum Value | Description |
|---|---|
|
|
When tenant subscribes to this, they will be notified whenever they try to charge an account that does not exist. |
|
|
When tenant subscribes to this, they will be notified whenever they try to charge a device that does not exist. |
|
|
When tenant subscribes to this, they will be notified whenever rating plan cannot be found when processing a charge request. |
|
|
When tenant subscribes to this, they will be notified whenever they try to update or terminate a session that does not exist. |
|
|
When tenant subscribes to this, they will be notified whenever they try to update or terminate a session that is closed. |
|
|
When tenant subscribes to this, they will be notified whenever they are trying to use a rate anything plan that contains invalid expression(s). |
Example
"ACCOUNT_NOT_FOUND"
Termination
Fields
| Field Name | Description |
|---|---|
aNumberHomeCountryExpr - String!
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) |
bNumberCurrentCountryExpr - String
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) Only |
currentOperatorExpr - String
|
An MCC/MNC expression that allows for wildcards, conjunction, and negation and identifies the operator network. For example, specifying: 505/* - All of Australia and its territories. 31*/* - All of the US. 310/(350,012) - Two specific Verizon networks in the US. This uses an OR. {31*, !310/(350,012)} - All of the US except two specific Verizon networks. This is an outer AND and an inner OR. Only |
Example
{
"aNumberHomeCountryExpr": "xyz789",
"bNumberCurrentCountryExpr": "abc123",
"currentOperatorExpr": "abc123"
}
TerminationInput
Description
Information about A and B parties for MT calls.
Fields
| Input Field | Description |
|---|---|
aNumberHomeCountryExpr - String!
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) |
bNumberCurrentCountryExpr - String
|
ISO 3166-1 alpha-2 country code. For example, US. The list can be found here: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 Negation can be used. For example, !US. Conjunction can be used. For example, (US,CA). This means US OR CA. Other valid examples are (US,!CA) , !(US,!CA) Only |
currentOperatorExpr - String
|
An MCC/MNC expression that allows for wildcards, conjunction, and negation and identifies the operator network. For example, specifying: 505/* - All of Australia and its territories. 31*/* - All of the US. 310/(350,012) - Two specific Verizon networks in the US. This uses an OR. {31*, !310/(350,012)} - All of the US except two specific Verizon networks. This is an outer AND and an inner OR. Only currentOperatorExpr or bNumberCurrentCountryExpr can be specified but not both, they are exclusive. |
Example
{
"aNumberHomeCountryExpr": "xyz789",
"bNumberCurrentCountryExpr": "xyz789",
"currentOperatorExpr": "abc123"
}
TimePeriod
Description
Consists of times and days to make an overall period (e.g. Mon-Fri 09:00-18:00 as working hours period). It should have times specified or days specified or both.
Fields
| Field Name | Description |
|---|---|
times - [String!]
|
A list of time intervals in a format of HH:mm-HH:mm (10:32-15:43) or hh24:mm-hh24:mm (10:32am-3:43pm). |
days - [WeekDay!]
|
A list of week days. |
Example
{"times": ["xyz789"], "days": ["MONDAY"]}
TimePeriodInput
Description
Input type of TimePeriod. It should have times specified or days specified or both.
Fields
| Input Field | Description |
|---|---|
times - [String!]
|
A list of time intervals in a format of HH:mm-HH:mm (10:32-15:43) or hh24:mm-hh24:mm (10:32am-3:43pm). |
days - [WeekDay!]
|
A list of week days. |
Example
{"times": ["abc123"], "days": ["MONDAY"]}
TimestampConfiguration
TransactionHasBeenProcessed
Description
An error type to be thrown if the transaction has been processed.
Example
{
"providerId": "4",
"transactionId": 4,
"errorCode": "xyz789",
"errorMessage": "abc123"
}
TriggerRarInput
TriggerRarPayload
TriggerRarResult
Description
Return type of TriggerRar including all possible errors.
AccountNotFound (AccountNotFound)- The specified account does not exist.RarNotEnabled (RarNotEnabled)- The RAR feature is not enabled for the provider.
Types
| Union Types |
|---|
Example
TriggerRarPayload
UnitPlanService
Description
Type definition for a unit plan service with allowances and rollover.
This type is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan service. |
name - String!
|
The name of the plan service. |
ratingGroups - [Int!]!
|
The rating groups supported by the service. |
priority - Float
|
The priority of the service compared to others. |
restrictions - [String!]
|
Restriction expressions of the Service. All of them must evaluate to true for the service to apply. |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. |
balanceTypes - [ID!]!
|
The balance types that can be charged by the service. |
managedBalance - ManagedBalance
|
Configuration for managed balance with allowances and rollover. |
Example
{
"providerId": "4",
"id": 4,
"name": "abc123",
"ratingGroups": [987],
"priority": 987.65,
"restrictions": ["abc123"],
"denyOtherServices": true,
"balanceTypes": ["4"],
"managedBalance": ManagedBalance
}
UnitPlanServiceInput
Description
Input to define a unit plan service with allowances and rollover.
Fields
| Input Field | Description |
|---|---|
name - String
|
Name of the plan service. Generated if not provided. |
ratingGroups - [Int!]!
|
The rating groups supported by the service. |
priority - Float
|
Defines the priority of the service compared to others. |
restrictions - [String!]
|
Restriction expressions of the Service. All of them must evaluate to true for the service to apply. |
denyOtherServices - Boolean
|
If provided and current service can serve a request (even if it does not have enough balance to do that), then no other services next in the order will be executed. By default it is false. |
balanceTypes - [ID!]!
|
The balance types that can be charged by the service. |
managedBalance - ManagedBalanceInput
|
Configuration for managed balance with allowances and rollover. |
Example
{
"name": "xyz789",
"ratingGroups": [987],
"priority": 987.65,
"restrictions": ["abc123"],
"denyOtherServices": false,
"balanceTypes": [4],
"managedBalance": ManagedBalanceInput
}
UnitType
Description
Possible types of units that will be granted.
Values
| Enum Value | Description |
|---|---|
|
|
Time type of units. Seconds for example. |
|
|
Volume type of units. Bytes for example. |
|
|
Any service specific types of units. SMS for example. |
Example
"TIME"
UnlimitedPlanService
Description
Type definition for an unlimited plan service.
This type is reserved for the upcoming Rate Anything capability, enabling customers to configure rates based on any attribute from the network message or subscriber database, such as birthday or class. Further details will be provided as the feature is rolled out.
Fields
| Field Name | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
id - ID!
|
A unique identifier of a plan service. |
name - String!
|
The name of the plan service. |
ratingGroups - [Int!]!
|
The rating groups supported by the service. |
priority - Float
|
The priority of the service compared to others. |
restrictions - [String!]
|
Restriction expressions of the Service. All of them must evaluate to true for the service to apply. |
balanceType - ID!
|
The balance type consumed by the service. |
Example
{
"providerId": 4,
"id": "4",
"name": "abc123",
"ratingGroups": [123],
"priority": 123.45,
"restrictions": ["xyz789"],
"balanceType": "4"
}
UnlimitedPlanServiceInput
Description
Input to define an unlimited plan service.
Fields
| Input Field | Description |
|---|---|
name - String
|
Name of the plan service. Generated if not provided. |
ratingGroups - [Int!]!
|
The rating groups supported by the service. |
priority - Float
|
Defines the priority of the service compared to others. |
restrictions - [String!]
|
Restriction expressions of the Service. All of them must evaluate to true for the service to apply. |
balanceType - ID!
|
The balance type consumed by the service. |
Example
{
"name": "xyz789",
"ratingGroups": [987],
"priority": 987.65,
"restrictions": ["abc123"],
"balanceType": "4"
}
UpdateAccountBalanceTypeCounterInput
Description
Input parameters for updating Balance Type Counter settings for an account. Updates an AccountBalanceCounter record.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Provider ID. |
balanceTypeId - ID!
|
The balanceType ID for which to update a Counter in the Account. |
accountId - ID!
|
ID of the Accout whose Balance Type Counter will be modified. |
counter - BalanceTypeCounterInput!
|
The information about the counter. |
Example
{
"providerId": 4,
"balanceTypeId": 4,
"accountId": "4",
"counter": BalanceTypeCounterInput
}
UpdateAccountInput
Description
Input type of UpdateAccount.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
accountId - ID!
|
A unique identifier of an account. |
customData - AWSJSON
|
Any custom data required by the account. |
friendsAndFamily - [String]
|
List of friends and family. This field is deprecated in favor of custom fields. Deprecated date is 2025-02-14. Expiration date is 2025-04-13. |
creditLimit - Float
|
The limit an account can be credited to. It should be negative/zero for prepaid accounts and positive for postpaid accounts. |
notificationCreditLimitThresholds - [Float]
|
Thresholds of the default monetary balance on the account. Whenever the account balance goes lower than any of the values in the set a notification is sent. |
postpaid - UpdateAccountPostpaidPropertiesInput
|
If account is a postpaid account, i.e. creditLimit is greater than zero, this holds the postpaid properties |
accountLifecycle - AccountLifecycleInput
|
Initial Lifecycle and state to assign to the new account |
Example
{
"providerId": 4,
"accountId": "4",
"customData": AWSJSON,
"friendsAndFamily": ["xyz789"],
"creditLimit": 123.45,
"notificationCreditLimitThresholds": [987.65],
"postpaid": UpdateAccountPostpaidPropertiesInput,
"accountLifecycle": AccountLifecycleInput
}
UpdateAccountPayload
Description
Return type of UpdateAccount.
Fields
| Field Name | Description |
|---|---|
account - Account!
|
The updated account. |
Example
{"account": Account}
UpdateAccountPostpaidPropertiesInput
Description
An input type to hold the postpaid properties of accounts
Fields
| Input Field | Description |
|---|---|
timezone - String
|
The timezone of the user in +/-hh:mm or Country/City format. This is a property for postpaid accounts only. |
billingDayOfMonth - Int
|
The day of month for resetting balance and units for account. Value is between 1 and 31 inclusive. This is a property for postpaid accounts only. |
longFirstBillingCycle - Boolean
|
Whether the new billing cycle is a long one, e.g. if current date is the 1st and the account was updated to use the 16th. If this value is true, it means that the next bill will be for 45 days, while if false, bill will be for 15 days only. If not provided then used already existing value for this account. |
Example
{
"timezone": "abc123",
"billingDayOfMonth": 123,
"longFirstBillingCycle": false
}
UpdateAccountResult
Description
Return type of UpdateAccount including all possible errors.
LifecycleNotFound (LifecycleNotFound)- The specified lifecycle doesn't exist.InvalidField (InvalidLifecycleState)- The state for the lifecycle is invalid.InvalidField (InvalidFriendsAndFamilyList)- Friends and family list can consist of 20 numbers maximum.InvalidField (InvalidFriendsAndFamilyNumber)- Friends and family list consists of invalid number. The only allowed format is E.164.InvalidField (InvalidJsonCreditLimit)- Cannot set credit limit from json.creditLimit. Must use creditLimit directly.InvalidField (InvalidJsonCustomData)- The provided customData is an invalid JSON.InvalidField (InvalidTimezone)- Timezone format is wrong. It should be between -12:00 and +14:00 or use a Country/City format.InvalidField (InvalidDayOfMonth)- Billing day of month should be between 1 and 31 inclusive.
Example
UpdateAccountPayload
UpdateArchivingPolicyFailed
Description
An error type to be thrown if updating archive policy fails.
Example
{
"providerId": 4,
"archiveThreshold": 123,
"errorCode": "abc123",
"errorMessage": "abc123"
}
UpdateArchivingPolicyInput
UpdateArchivingPolicyPayload
Description
Return type of UpdateArchivingPolicy.
Example
{"providerId": 4, "oldArchiveThreshold": 123, "newArchiveThreshold": 987}
UpdateArchivingPolicyResult
Description
Return type of updateArchivingPolicy and all possible errors.
UpdateArchivingPolicyFailed (ErrorSavingArchivingPolicy)- The propagated error message coming from S3.UpdateArchivingPolicyFailed (InvalidArchivingThreshold)- The provided archiveThreshold is invalid. Value should be greater than 0.
Example
UpdateArchivingPolicyPayload
UpdateBalanceInfoInput
Description
Input type for updating a balance details.
Fields
| Input Field | Description |
|---|---|
balanceTypeId - ID!
|
Balance type ID. |
priority - Float
|
Priority of the balance. If there are multiple balances of the same type, the one with the highest priority will be used first. |
balanceValue - Float
|
Value of the balance. |
adjustment - AdjustmentType
|
Value of the adjustment to the current balance. The default value is NONE. |
limit - Float
|
Limit for the balance. |
from - AWSDateTime
|
Start date of the balance. |
to - AWSDateTime
|
End date of the balance. |
Example
{
"balanceTypeId": "4",
"priority": 987.65,
"balanceValue": 987.65,
"adjustment": "CREDIT",
"limit": 123.45,
"from": AWSDateTime,
"to": AWSDateTime
}
UpdateBalanceInput
Description
Input type for updating a balance.
Fields
| Input Field | Description |
|---|---|
balanceId - ID!
|
ID for the balance. |
providerId - ID!
|
Provider ID. |
accountId - ID!
|
Account ID. |
balanceInfo - UpdateBalanceInfoInput!
|
Balance info. |
transactionId - ID
|
An optional transaction ID to ensure idempotency of the API call if required. |
Example
{
"balanceId": 4,
"providerId": 4,
"accountId": 4,
"balanceInfo": UpdateBalanceInfoInput,
"transactionId": "4"
}
UpdateBalanceResult
Description
Return type of UpdateBalance including all possible errors.
TransactionHasBeenProcessed (TransactionHasBeenProcessed)- The transaction has been processed.BalanceNotFound (BalanceNotFound)- The balance ID provided does not exist.AccountNotFound (AccountNotFound)- The specified account does not exist.BalanceTypeNotFound (BalanceTypeNotFound)- None of the balance type IDs provided does exist.InvalidField (BalanceLimitViolation)- When the balance total exceeds the balance or balance type limit or limit exceeds the limit in balance type.InvalidField (UnlimitedBalanceCannotBeChanged)- When attempting to change the balance value of an unlimited balance.
Example
BalancePayload
UpdateBalanceTypeCounterInput
Description
Input parameters for updating Balance Type Counter notifications.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Provider ID. |
balanceTypeId - ID!
|
The balanceType ID associated with the Balance Type Counter Creates or updates the counter for the correct Balance Type. |
counter - BalanceTypeCounterInput!
|
The information about the counter. |
Example
{
"providerId": 4,
"balanceTypeId": "4",
"counter": BalanceTypeCounterInput
}
UpdateBalanceTypeCounterPayload
Description
A representation of Balance Type Counter notifications.
Fields
| Field Name | Description |
|---|---|
balanceTypeId - ID!
|
The Balance Type associated with the Balance Type Counter. |
counter - BalanceTypeCounterPayload!
|
The counter information payload. |
Example
{"balanceTypeId": 4, "counter": BalanceTypeCounterPayload}
UpdateBalanceTypeInput
Description
Input type for updating a balance type.
Fields
| Input Field | Description |
|---|---|
balanceTypeId - ID!
|
ID for the balance type. |
providerId - ID!
|
Provider ID. |
name - String!
|
Name of the balance type. Has to be unique across a tenant. |
unitType - UnitType!
|
Unit type of the balance type. |
limit - Float
|
Limit of the balance type. If the balance is rate based, it is equivalent creditLimit. |
counters - [BalanceTypeCounterInput!]
|
List of balance type counter inputs of the balance type. |
Example
{
"balanceTypeId": "4",
"providerId": "4",
"name": "abc123",
"unitType": "TIME",
"limit": 987.65,
"counters": [BalanceTypeCounterInput]
}
UpdateBalanceTypeResult
Description
Return type of UpdateBalanceType including all possible errors.
BalanceTypeNameInUse (BalanceTypeNameInUse)- The balance type name is already in use.BalanceTypeHasReferences (BalanceTypeHasReferences)- The balance type is used in an active plan and the unit type and name can't be updated.BalanceTypeNotFound (BalanceTypeNotFound)- The balance type ID provided does not exist.BalanceTypeCounterNotFound (BalanceTypeCounterNotFound)- One of the counter IDs does not exist.InvalidField (InvalidLimit)- The limit has to be an integer value if it is not a rate based balance type. Only rate based balance types can have decimal limits.InvalidField (InvalidCounterName)- The provided counter name must be between 1 and 50 characters and consist of letters, digits or special characters.InvalidField (InvalidCounterNames)- Counter names must be unique across the balance type.InvalidField (InvalidCounterStates)- Thresholds and names of states must be unique across the counter and one of the states must not have a threshold.
Example
BalanceTypePayload
UpdateClientCredentialsInput
Description
Input type for updateClientCredentials API.
Fields
| Input Field | Description |
|---|---|
name - String!
|
A descriptive name for the client credentials. |
roleGroupMemberships - [RoleGroup!]!
|
The roles assigned to the client credentials. |
Example
{
"name": "xyz789",
"roleGroupMemberships": ["Account_Query"]
}
UpdateClientCredentialsResult
Description
Return type of updateClientCredentials, including all possible errors.
ProviderNotFound- The specifiedproviderIddoes not exist.ClientNotFound- The specified client credentialsiddoes not exist.InvalidField (RoleGroupMemberships)- A non-valid role group was provided
Types
| Union Types |
|---|
Example
ClientCredentials
UpdateDeviceInput
Description
Input type of UpdateDevice.
Example
{
"providerId": "4",
"accountId": 4,
"deviceId": 4,
"customData": AWSJSON
}
UpdateDevicePayload
Description
Return type of UpdateDevice.
Fields
| Field Name | Description |
|---|---|
device - Device!
|
The updated device. |
Example
{"device": Device}
UpdateDeviceResult
Description
Return type of UpdateDevice including all possible errors.
InvalidField (InvalidJsonCustomData)- The provided customData is an invalid JSON.
Example
UpdateDevicePayload
UpdateFieldMappingInput
Description
Input type of UpdateFieldMapping.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
path - String!
|
The path to the field you want to manipulate. For example, "transformedRequest.sMSChargingInformation.numberofMessagesSent". The path must start from either "transformedRequest." or "transformedResponse." and must be an existing path. If provided path does not exist in request or response, only the last key should not exist. For example, "transformedResponse.invocationResult.message" is allowed, while "transformedResponse.invocationResult.message.text" is not allowed, because message is a new key already. It is possible to set a new field to a list. Originally SpEL does not support that, but we iterate over lists with provided [] after them. For example, "transformedRequest.multipleUnitUsage[].usedUnitContainer[].timeSpecificUnits", both multipleUnitUsage and usedUnitContainer are arrays, it means eventually field mapper will add to each item in these lists a new key "timeSpecificUnits". For the N28/SY interface, the path must start from either "transformedN28Request" or "transformedN28Response". You can then set the custom "tenantIdentifier" field by using the path "transformedN28Request.tenantIdentifier". This field can and will not be set on deleting spending limit subscriptions but the subscription ID will be used. |
expr - String!
|
SpEL expression to generate the value(s). It must return one value, but also it can use the same expressions as "path" with []. For example, "originalRequest.multipleUnitUsage[].usedUnitContainer[].serviceSpecificUnits * 10". It is also possible to use "originalField" as a reference to original value if field exists. For example, "originalField + 10". For the N28/SY interface, the expression must start with either "originalN28Request" or "originalN28Response". |
Example
{
"providerId": 4,
"path": "xyz789",
"expr": "xyz789"
}
UpdateFieldMappingPayload
Description
Return type of UpdateFieldMapping.
Fields
| Field Name | Description |
|---|---|
fieldMapping - FieldMapping!
|
Updated field mapping. |
Example
{"fieldMapping": FieldMapping}
UpdateFieldMappingResult
Description
Return type of UpdateFieldMapping including all possible errors.
InvalidField (InvalidFieldMappingExpression)- The provided field mapping SpEL expression cannot be compiled.
Example
UpdateFieldMappingPayload
UpdateLifecycleInput
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
lifecycleId - ID!
|
Lifecycle ID. |
name - String
|
Descriptive name |
customData - AWSJSON
|
Any custom data; typically only used by Plan Design UI. |
states - [LifecycleStateInput!]
|
Lifecycle Definition; first state is used as the default. |
Example
{
"providerId": "4",
"lifecycleId": "4",
"name": "xyz789",
"customData": AWSJSON,
"states": [LifecycleStateInput]
}
UpdateLifecycleResult
Description
Return type of CreateAccount including all possible errors.
InvalidNumberOfStates (InvalidNumberOfStates)- The lifecycle requires at least one state.InvalidStateTransitions (InvalidStateTransitions)- Transitions need to be to a valid state.LifecycleNotFound (LifecycleNotFound)- The specified lifecycle doesn't exist.InvalidStateTransitions (InvalidExpiryState)- Transition state on expiry need to be in state's list of transitions.InvalidField (InvalidExpiryDays)- expiryDays exceed maxDays.InvalidField (InvalidCustomDataSize)- customData size exceeds max size.
Example
LifecyclePayload
UpdateMyProviderConfigInput
Fields
| Input Field | Description |
|---|---|
name - String
|
The name of the tenant. Stays the same if not provided. |
commonName - String
|
The common name that will be used in the SSL certificates of the tenant. Stays the same if not provided. |
homeNetworks - String
|
The home networks for the tenant. Required if onNet calls should be supported. Stays the same if not provided. |
emergencyNumbers - [String]
|
List of emergency numbers. Stays the same if not provided. |
carrierCode - String
|
The carrier code. Stays the same if not provided. |
eventBusArn - String
|
The ARN of the event bus that we should be sending events to. |
activeAlarms - [TenantAlarmType]
|
The tenant specific alarms the provider is subscribed to. |
failureHandling - FailureHandling
|
Failure handling strategy. Default is RETRY_AND_TERMINATE. |
rarEnabled - Boolean
|
Whether RAR notifications are enabled or not. Defaults to false. |
insufficientBalanceSessionHandling - InsufficientBalanceSessionHandling
|
Insufficient balance handling strategy for session-based charging. Defaults to PROVIDE_ROUNDED_AMOUNT. Rate Anything requests with PROVIDE_ROUNDED_AMOUNT will be handled just like PROVIDE_REMAINING. |
insufficientBalanceEventHandling - InsufficientBalanceEventHandling
|
Insufficient balance handling strategy for event-based charging. Defaults to PROVIDE_ROUNDED_AMOUNT. Rate Anything requests with PROVIDE_ROUNDED_AMOUNT will be handled just like REJECT. |
Example
{
"name": "xyz789",
"commonName": "abc123",
"homeNetworks": "xyz789",
"emergencyNumbers": ["abc123"],
"carrierCode": "xyz789",
"eventBusArn": "xyz789",
"activeAlarms": ["ACCOUNT_NOT_FOUND"],
"failureHandling": "TERMINATE",
"rarEnabled": true,
"insufficientBalanceSessionHandling": "IGNORE",
"insufficientBalanceEventHandling": "REJECT"
}
UpdateMyProviderConfigResult
Description
Return type of UpdateMyProviderConfig including all possible errors.
InvalidField (WrongNameLength)- Name length must be between 2 and 50 characters.InvalidProviderLifecycleStage- Provider user can't call API when provider lifecycle stage is CREATING, SUSPENDED, TERMINATED or DELETED.InvalidField (CommonNameExists)- The common name exists for a non-deleted provider.
Example
ProviderConfig
UpdatePlanInput
Description
Input type of UpdatePlan.
Fields
| Input Field | Description |
|---|---|
providerId - ID
|
A unique identifier of a service provider. Important: This input field is used by old template API and is deprecated. For the new Beta API for RA plans specify it in the arguments instead. Deprecated date is 2025-06-01. Expiration date is 2025-09-01. Specifies providerId for old template API. For the new Beta API for RA plans specify it in the arguments instead. Deprecated date is 2025-06-01. Expiration date is 2025-09-01. |
planId - ID
|
A unique identifier of a plan to update. Important: This input field is used by old template API and is deprecated. For the new Beta API for RA plans specify it in the arguments instead. Deprecated date is 2025-06-01. Expiration date is 2025-09-01. Specifies planId for old template API. For the new Beta API for RA plans specify it in the arguments instead. Deprecated date is 2025-06-01. Expiration date is 2025-09-01. |
name - String
|
A human readable name. Not unique. |
Example
{
"providerId": 4,
"planId": "4",
"name": "xyz789"
}
UpdatePlanPayload
Description
Return type of UpdatePlan.
Important: This type is deprecated. Only template APIs are supported moving forward. Deprecated date is 2024-10-31. Expiration date is 2025-01-31.
Fields
| Field Name | Description |
|---|---|
plan - Plan!
|
Updated plan. |
Example
{"plan": Plan}
UpdatePlanResult
Description
Return type of UpdatePlan including all possible errors.
InvalidField (InvalidName)- The provided name must be between 2 and 50 characters and consist of letters, digits or special characters.InvalidField (InvalidServiceName)- The provided name must be between 2 and 50 characters and consist of letters, digits or special characters.InvalidField (DuplicatedServiceName)- Service names must be unique across the plan version.InvalidField (InvalidRatingGroup)- There is no provided rating group ID in the hierarchy or provided rating group ID is the Root.InvalidField (EmptyBalanceTypes)-balanceTypesmust not be empty.InvalidField (InvalidBalanceTypeIds)- Balance Type Ids inbalanceTypeIdsmust be unique.InvalidField (InvalidBalanceTypes)- Balance Type Ids inbalanceTypesmust be unique.InvalidField (InvalidBalanceTypeIds)- All balance Type Ids inbalanceTypeIdsmust be Ids of either rate based balance types or not rate based balance types. Mixing is not allowed.InvalidField (InvalidBalanceTypes)- UnitPlanService only supports non-rate based balance types.InvalidField (InvalidManagedBalanceTypeId)-balanceTypeIdsdoes not include 'managedBalanceTypeId'.InvalidField (InvalidManagedBalanceTypes)-balanceTypesdoes not include 'managedBalanceTypeId'.InvalidField (MissingField)- The periodAllowance must be provided and must be greater than zero when managedBalance is used for unit plan services.InvalidField (InvalidRolloverSettings)- The fields maxRolloverPeriods, rolloverAllowance, rolloverMaxAllowance must not be provided if rollover is set to false.InvalidField (InvalidRolloverSettings)- Rollover, maxRolloverPeriods, rolloverAllowance, rolloverMaxAllowance must not be provided if periodAllowance is not provided or 0 (unlimited).InvalidField (InvalidInteger)- The provided number can be only an integer.InvalidField (ExpressionValidationFailed)- Invalid expression in service restrictions or rateOptions.restrictions.
Important: This type is deprecated. Only template APIs are supported moving forward. Deprecated date is 2024-10-31. Expiration date is 2025-01-31.
Example
PlanPayload
UpdatePlanSubscriptionInput
Description
Input type of UpdatePlanSubscription.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
accountId - ID!
|
A unique identifier of an account. |
planSubscriptionId - ID!
|
A unique identifier of a plan subscription to use. |
planVersionId - ID
|
The unique identifier of a specific plan version to which the subscription will be switched. When switching to a new plan, provide only one of the following: Opt for |
planId - ID
|
A unique identifier of a plan reference to subscribe to. When switching a subscription to a new plan or version, provide only one of the following: If there is no active version of the plan at the time of the API call, SubscribeToPlan will raise an error even if the subscription is for a future date. |
overrides - [KeyValueInput]
|
List of fields with values that override values from a plan. |
from - AWSDateTime
|
The start time of the subscription. Set to now if not provided. |
to - AWSDateTime
|
The end time of the subscription. Set to a far time into the future if not provided. |
Example
{
"providerId": 4,
"accountId": "4",
"planSubscriptionId": "4",
"planVersionId": "4",
"planId": 4,
"overrides": [KeyValueInput],
"from": AWSDateTime,
"to": AWSDateTime
}
UpdatePlanVersionFromInitialRecurringFirstUsageTemplateInput
Description
Input type of UpdatePlanVersionFromInitialRecurringFirstUsageTemplate.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
planVersionId - ID!
|
An existing plan version ID to be updated. |
version - String
|
The name of the version to be updated. Remains not changed if not provided. |
recurringFirstUsageFee - Float!
|
A fee that will be charged every time after the recurringFirstUsagePeriod expires. Currently, this is at the next hour for hourly plans, at next midnight of the account timezone for daily plans, at next Saturday midnight of the account timezone for weekly plans, and at the last day of the month midnight of the account timezone for monthly plans. |
recurringFirstUsagePeriodType - PeriodType!
|
The period type at which the recurringFirstUsageFee is charged, hourly, daily, weekly, monthly. |
services - [InitialRecurringFirstUsageTemplateServiceInput!]
|
List of plan services. Remains not changed if not provided. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. Remains not changed if not provided. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. Remains not changed if not provided. |
policies - [PolicyInput!]
|
Policies to attach to the plan version. When provided, replaces all existing policies. Pass an empty list to clear all policies. Omit to keep existing policies unchanged. |
Example
{
"providerId": "4",
"planVersionId": 4,
"version": "xyz789",
"recurringFirstUsageFee": 123.45,
"recurringFirstUsagePeriodType": "HOUR",
"services": [
InitialRecurringFirstUsageTemplateServiceInput
],
"json": AWSJSON,
"priority": 123.45,
"policies": [PolicyInput]
}
UpdatePlanVersionFromInitialTemplateInput
Description
Input type of UpdatePlanVersionFromInitialTemplate.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
planVersionId - ID!
|
An existing plan version ID to be updated. |
version - String
|
The name of the version to be updated. Remains not changed if not provided. |
fee - Float
|
A fee that will be charged per specified recurring period. Recurring fee is charged first time after the first period. If you need to charge some fee on subscription you need to use purchaseFee. Remains not changed if not provided. |
firstUsageFee - Float
|
A fee that will be charged just once on first usage of the plan. Remains not changed if not provided. |
purchaseFee - Float
|
A fee that will be charged just once right after the subscription. Remains not changed if not provided. |
period - RecurringPeriodInput
|
A period when specified fee will be charged. Remains not changed if not provided. |
services - [InitialTemplateServiceInput!]
|
List of plan services. Remains not changed if not provided. A plan service can only specify a monetary or unit rate but not both, they are exclusive. |
notificationPeriodsBeforeExpiration - [Int]
|
A set of periods in seconds when to send multiple notifications before the plan expires. Remains unchanged if not provided. |
renewalGracePeriod - [DurationInput]
|
Put a plan on hold for a limited grace period while waiting for a successful renewal. It is a sum of provided duration inputs. |
json - AWSJSON
|
Custom data in JSON format to be able to save and retrieve some configurations. Remains not changed if not provided. |
priority - Float
|
Plan priority that determines the execution order for charging and rating. Remains not changed if not provided. |
proratingOptions - ProratingOptionsInput
|
The prorating options for the plan |
policies - [PolicyInput!]
|
Policies to attach to the plan version. When provided, replaces all existing policies. Pass an empty list to clear all policies. Omit to keep existing policies unchanged. |
Example
{
"providerId": "4",
"planVersionId": "4",
"version": "abc123",
"fee": 123.45,
"firstUsageFee": 987.65,
"purchaseFee": 987.65,
"period": RecurringPeriodInput,
"services": [InitialTemplateServiceInput],
"notificationPeriodsBeforeExpiration": [987],
"renewalGracePeriod": [DurationInput],
"json": AWSJSON,
"priority": 987.65,
"proratingOptions": ProratingOptionsInput,
"policies": [PolicyInput]
}
UpdatePlanVersionFromInitialTemplateResult
Description
Return type of UpdatePlanVersionFromInitialTemplate including all possible errors.
InvalidField (InvalidExtendedRate)- In the roaming or long distance one of the inputs (origination or termination) must be provided.InvalidField (InvalidRatingGroup)- There is no provided rating group ID in the hierarchy or provided rating group ID is the Root.InvalidField (SubscriptionPolicy)- If "alignBillingToDoM" is set to false and "subscriptionPolicy" was anything other than NONE or emptyInvalidField (RefundPolicy)- If "alignBillingToDoM" is set to false and "refundPolicy" was anything other than NONE or emptyInvalidField (ProratingOptionsSetForNonMonthlyPlan)- If "alignBillingToDoM" is set to true for a non monthly planBalanceTypeNotFound (BalanceTypeNotFound)- One of the provided balance type IDs does not exist.CreatePlanValidationFailed (FeeIsNotRequired)- Fee is provided for a non recurring plan. Recurring plan must have a period specified and this period must be marked as recurring.CreatePlanValidationFailed (BaseVersionIsNotTemplate)- The specified planVersionId is not a template version.ServiceFormatError (ServiceFormatError)- A new version of a plan is created based on the old format while a version with the new format exists. As soon as a plan uses the new balance format, all versions of the plan must use the new format.
Example
PlanVersionPayload
UpdatePlanVersionSubscriptionResult
Description
Return type of UpdatePlanSubscription including all possible errors.
SubscribeToPlanVersionValidationFailed (SubscriptionDateCannotExceedPlanPeriod)- should be returned when the plan is non recurring and the subscription exceeds the plan period length.SubscribeToPlanVersionValidationFailed (ActiveSubscriptionFromDateIsReadOnly)- The “from” date of an active subscription cannot be changed.PlanVersionNotFound (PlanVersionNotFound)- The requested plan version with the provided ID cannot be found.PlanNotFound (PlanNotFound)- The requested plan with the provided ID cannot be found.PlanAliasNotFound (PlanAliasNotFound)- The requested plan alias with the provided ID cannot be found.PlanAliasNotActive (PlanAliasNotActive)- The requested plan alias with the provided ID does not have an active version.PlanVersionIsNotAssignable (PlanVersionIsNotAssignable)- The requested plan version is marked as not assignable. Please, make it assignable first.AccountNotFound (AccountNotFound)- The requested account with the provided ID cannot be found.SubscriptionNotFound (SubscriptionNotFound)- The plan subscription with the provided ID was not found.InvalidField (OnlyOnePlanToBeProvided)- You cannot provide both planId and planVersionId.InvalidField (PlanMustBeProvided)- Either planId or planVersionId must be provided.InvalidField (InvalidFutureDate)- The provided date cannot be in the past.InvalidField (InvalidDatesRange)- The provided "to" date cannot be earlier than the provided "from" date..InternalServerError (ChargeEngineNotAvailable)- The charge engine is not available at this time.
Types
| Union Types |
|---|
Example
SubscribeToPlanVersionPayload
UpdateQoSProfilePayload
Description
Payload for successful QoS Profile update.
Fields
| Field Name | Description |
|---|---|
qosProfile - QoSProfile!
|
The updated QoS profile |
Example
{"qosProfile": QoSProfile}
UpdateQoSProfileResult
Description
Result type for updateQoSProfile mutation.
Types
| Union Types |
|---|
Example
UpdateQoSProfilePayload
UpdateRatingGroupHierarchyInput
Description
Input type of UpdateRatingGroupHierarchy.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
A unique identifier of a service provider. |
root - RatingGroupInput!
|
Root rating group where the whole hierarchy starts. |
Example
{
"providerId": "4",
"root": RatingGroupInput
}
UpdateRatingGroupHierarchyPayload
Description
Return type of UpdateRatingGroupHierarchy.
Fields
| Field Name | Description |
|---|---|
root - RatingGroup!
|
Root rating group where the whole hierarchy starts. |
Example
{"root": RatingGroup}
UpdateRatingGroupHierarchyResult
Description
Return type of UpdateRatingGroupHierarchy including all possible errors.
RatingGroupValidationFailed (DefaultRatingGroupIsNotProvided)- Mandatory default rating group(s) were not provided with a new hierarchy.RatingGroupValidationFailed (RatingGroupIsDuplicated)- Each rating group ID must be unique.RatingGroupValidationFailed (UnitRoundingInvalidLevel)- Unit rounding can be set only on the second level of hierarchy (the next after Root).RatingGroupValidationFailed (MissingMinReservationForDynamicQuota)- The minReservations should be defined on the same or upper level of the rating group hierarchy when Dynamic Quota Allocation is enabled.RatingGroupValidationFailed (MissingQuotaValidityTimeForDynamicQuota)- The quotaValidityTime should be defined on the same or upper level of the rating group hierarchy when Dynamic Quota Allocation is enabled.RatingGroupHierarchyHasReferences (RatingGroupHierarchyHasReferences)- A node in the hierarchy can not be removed or changed if there are any active Plans referring to it.InvalidField (InvalidReservations)- The max reservation must be greater than the min reservation.InvalidField (InvalidPositiveNumber)- The provided number can be only a positive number.InvalidField (InvalidQuotaHoldingTime)- The provided number cannot be a negative number.
Example
UpdateRatingGroupHierarchyPayload
UpdateSGSNTableInput
Description
Input type of UpdateSGSNTable.
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Service provider ID. |
sgsnTable - SGSNTableInput!
|
A unique identifier of a service provider. |
Example
{
"providerId": "4",
"sgsnTable": SGSNTableInput
}
UpdateSGSNTablePayload
Description
Return type of UpdateSGSNTable.
Fields
| Field Name | Description |
|---|---|
sgsnTable - SGSNTable!
|
Updated table. |
Example
{"sgsnTable": SGSNTable}
UpdateSGSNTableResult
Description
Return type of UpdateSGSNTableResult including all possible errors.
InvalidField (InvalidISO3166CountryCode)- The provided string must be a country code and must be in ISO 3166-1 alpha-2 format.InvalidField (InvalidIPCIDR)- The IP CIDR provided is not valid.
Example
UpdateSGSNTablePayload
UpdateSettingsInput
Description
Input type of UpdateSettings.
Example
{
"providerId": "4",
"json": AWSJSON,
"enableDynamicQuotaTestMode": true
}
UpdateSettingsPayload
Description
Return type of UpdateSettings.
Fields
| Field Name | Description |
|---|---|
settings - Settings!
|
The updated settings. |
Example
{"settings": Settings}
UpdateSettingsResult
Description
Return type of UpdateSettings including all possible errors.
Example
UpdateSettingsPayload
UpdateUserInput
Description
Input type of UpdateUser
Fields
| Input Field | Description |
|---|---|
providerId - ID!
|
Service provider ID |
userId - ID!
|
Cognito User ID |
email - AWSEmail!
|
|
name - String!
|
The name of the user. Should be between 2 and 75 characters |
roleGroupMemberships - [RoleGroup!]!
|
The roles this user belong to |
phoneNumber - AWSPhone
|
The user's phone number |
jobTitle - String
|
The user's job title. If present, it should be between 2 and 50 characters |
expiry - AWSDateTime
|
The time when the user should expire. Used for temporary access. |
alertInterval - Int
|
The alarm interval in minutes when an email should be send to the user that access expires. Only used when expiry is specified. Can be 0 or not specified when expiry is specified which means no email is send. |
Example
{
"providerId": 4,
"userId": 4,
"email": AWSEmail,
"name": "xyz789",
"roleGroupMemberships": ["Account_Query"],
"phoneNumber": AWSPhone,
"jobTitle": "abc123",
"expiry": AWSDateTime,
"alertInterval": 987
}
UpdateUserProfileInput
Description
Input type of UpdateUserProfile
Example
{
"name": "xyz789",
"phoneNumber": AWSPhone,
"jobTitle": "xyz789"
}
UpdateUserProfileResult
Description
Return type of UpdateUser including all possible errors.
InvalidField (name)- Name should be at least two characters long and a maximum of seventy fiveInvalidField (jobTitle)- Job title should be at least two characters long and a maximum of fiftyInvalidField (InvalidEmailDomain)- Unable to call the API for the user in this domain
Example
SaveUserPayload
UpdateUserResult
Description
Return type of UpdateUser including all possible errors.
UserNotFound- Given user ID does not exist in the tenant, even if user ID exists in CognitoInvalidField (name)- Name should be at least two characters long and a maximum of seventy fiveInvalidField (jobTitle)- Job title should be at least two characters long and a maximum of fiftyUserIsReadOnly(UsersCanNotUpdateThemselves)- Updating own record should be done via update profileInvalidField (expiry)- Expiry needs to be in the future and needs to be a valid datetime stringInvalidField (alertInterval)- The alert interval can't be negativeInvalidField (InvalidEmailDomain)- Unable to call the API for the user in this domain
Example
SaveUserPayload
UserAlreadyExists
Description
An error type to be thrown if a user with the same email exists in the user pool. Provider ID and user ID are not returned to not expose them in case user exists for a different provider
Example
{
"email": AWSEmail,
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
UserIncorrectStatus
Description
An error type to be thrown if user was not verified yet. This is returned whether the user does not exist, or if the provider does not exist.
Example
{
"providerId": "4",
"userId": "4",
"state": "abc123",
"errorCode": "xyz789",
"errorMessage": "xyz789"
}
UserIsReadOnly
Description
An error type to be thrown if a user tries to update his/her own user record using the admin API instead of the update user profile API, or if they try to delete their own user record
Example
{
"errorCode": "xyz789",
"errorMessage": "abc123"
}
UserNotFound
Description
An error type to be thrown if user was not found for given provider. This is returned whether the user does not exist, or if the provider does not exist.
Example
{
"providerId": 4,
"userId": "4",
"errorCode": "abc123",
"errorMessage": "xyz789"
}
WeekDay
Description
The possible values for week days.
Values
| Enum Value | Description |
|---|---|
|
|
Monday. |
|
|
Tuesday. |
|
|
Wednesday. |
|
|
Thursday. |
|
|
Friday. |
|
|
Saturday. |
|
|
Sunday. |
Example
"MONDAY"