openapi: 3.0.0 info: title: 3gpp-ecr-control version: 1.0.1 description: | API for enhanced converage restriction control. © 2019, 3GPP Organizational Partners (ARIB, ATIS, CCSA, ETSI, TSDSI, TTA, TTC). All rights reserved. externalDocs: description: 3GPP TS 29.122 V15.4.0 T8 reference point for Northbound APIs url: 'http://www.3gpp.org/ftp/Specs/archive/29_series/29.122/' security: - {} - oAuth2ClientCredentials: [] servers: - url: '{apiRoot}/3gpp-ecr-control/v1' variables: apiRoot: default: https://example.com description: apiRoot as defined in subclause 5.2.4 of 3GPP TS 29.122. paths: /query: post: summary: Query the status of enhanced converage restriction for a UE. requestBody: required: true content: application/json: schema: $ref: '#/components/schemas/ECRControl' responses: '200': description: The requested information was returned successfully. content: application/json: schema: $ref: '#/components/schemas/ECRData' '400': $ref: 'TS29122_CommonData.yaml#/components/responses/400' '401': $ref: 'TS29122_CommonData.yaml#/components/responses/401' '403': $ref: 'TS29122_CommonData.yaml#/components/responses/403' '404': $ref: 'TS29122_CommonData.yaml#/components/responses/404' '411': $ref: 'TS29122_CommonData.yaml#/components/responses/411' '413': $ref: 'TS29122_CommonData.yaml#/components/responses/413' '415': $ref: 'TS29122_CommonData.yaml#/components/responses/415' '429': $ref: 'TS29122_CommonData.yaml#/components/responses/429' '500': $ref: 'TS29122_CommonData.yaml#/components/responses/500' '503': $ref: 'TS29122_CommonData.yaml#/components/responses/503' default: $ref: 'TS29122_CommonData.yaml#/components/responses/default' /configure: post: summary: Configure the enhanced converage restriction for a UE. requestBody: required: true content: application/json: schema: $ref: '#/components/schemas/ECRControl' responses: '200': description: The Enhanced Coverage Restriction setting was configured successfully.. content: application/json: schema: $ref: '#/components/schemas/ECRData' '400': $ref: 'TS29122_CommonData.yaml#/components/responses/400' '401': $ref: 'TS29122_CommonData.yaml#/components/responses/401' '403': $ref: 'TS29122_CommonData.yaml#/components/responses/403' '404': $ref: 'TS29122_CommonData.yaml#/components/responses/404' '411': $ref: 'TS29122_CommonData.yaml#/components/responses/411' '413': $ref: 'TS29122_CommonData.yaml#/components/responses/413' '415': $ref: 'TS29122_CommonData.yaml#/components/responses/415' '429': $ref: 'TS29122_CommonData.yaml#/components/responses/429' '500': $ref: 'TS29122_CommonData.yaml#/components/responses/500' '503': $ref: 'TS29122_CommonData.yaml#/components/responses/503' default: $ref: 'TS29122_CommonData.yaml#/components/responses/default' components: securitySchemes: oAuth2ClientCredentials: type: oauth2 flows: clientCredentials: tokenUrl: '{tokenUrl}' scopes: {} schemas: ECRControl: type: object properties: supportedFeatures: $ref: 'TS29571_CommonData.yaml#/components/schemas/SupportedFeatures' externalId: $ref: 'TS29122_CommonData.yaml#/components/schemas/ExternalId' msisdn: $ref: 'TS29122_CommonData.yaml#/components/schemas/Msisdn' restrictedPlmnIds: type: array items: $ref: 'TS29122_CommonData.yaml#/components/schemas/PlmnId' minItems: 0 description: Indicates a complete list (and possibly empty) of serving PLMNs where Enhanced Coverage shall be restricted. This attribute shall not be present for the query custom operation. allowedPlmnIds: type: array items: $ref: 'TS29122_CommonData.yaml#/components/schemas/PlmnId' minItems: 0 description: Indicates a complete list (and possibly empty) of serving PLMNs where Enhanced Coverage shall be allowed. This attribute shall not be present for the query custom operation. required: - supportedFeatures oneOf: - required: [externalId] - required: [msisdn] not: required: [restrictedPlmnIds, allowedPlmnIds] ECRData: type: object properties: supportedFeatures: $ref: 'TS29571_CommonData.yaml#/components/schemas/SupportedFeatures' visitedPlmnId: $ref: 'TS29122_CommonData.yaml#/components/schemas/PlmnId' restrictedPlmnIds: type: array items: $ref: 'TS29122_CommonData.yaml#/components/schemas/PlmnId' minItems: 0 description: Indicates a complete list (and possibly empty) of serving PLMNs where Enhanced Coverage shall be restricted. allowedPlmnIds: type: array items: $ref: 'TS29122_CommonData.yaml#/components/schemas/PlmnId' minItems: 0 description: Indicates a complete list (and possibly empty) of serving PLMNs where Enhanced Coverage shall be allowed. required: - supportedFeatures not: required: [restrictedPlmnIds, allowedPlmnIds]