Skip to content
LocationAPI.yaml 39.1 KiB
Newer Older
  title: MEC-013 Location API
  version: 1.1.1
  description: 'The MEC-013 Location API described using OpenAPI, which is based on the Open Mobile Alliance''s specification RESTful Network API for Zonal Presence'
    name: ETSI Forge copyright notice
    url: 'https://forge.etsi.org/etsi-forge-copyright-notice.txt'
  description: ETSI MEC013 V1.1.1 Location Service API
  url: 'http://www.etsi.org/deliver/etsi_gs/MEC/001_099/013/01.01.01_60/gs_mec013v010101p.pdf'
host: '127.0.0.1:8081'
basePath: /exampleAPI/location/v1/
schemes:
  - http
  - https
consumes:
  - application/json
produces:
  - application/json
parameters:
  Body.UserTrackingSubscription:
    name: userTrackingSubscription
    in: body
    description: User Tracking Subscription
    required: true
    schema:
      $ref: '#/definitions/UserTrackingSubscription'
  Body.ZonalTrafficSubscription:
    name: zonalTrafficSubscription
    in: body
    description: Zonal Traffic Subscription
    required: true
    schema:
      $ref: '#/definitions/ZonalTrafficSubscription'
  Body.ZoneStatusSubscription:
    name: zoneStatusSubscription
    in: body
    description: Zone Status Subscription
    required: true
    schema:
      $ref: '#/definitions/ZoneStatusSubscription'
  Path.AccessPointId:
    name: accessPointId
    in: path
    description: Access Point ID
    required: true
    type: string
  Path.SubscriptionId:
    name: subscriptionId
    in: path
    description: Subscription ID
    required: true
    type: string
  Path.UserId:
    name: userId
    in: path
    description: User ID
    required: true
    type: string
  Path.ZoneId:
    in: path
  Query.AccessPointId:
    name: accessPointId
    in: query
    description: 'Identifier of access point, reference "definitions" for string format'
    required: false
    type: string
  Query.InterestRealm:
    description: 'Interest realm of access point (e.g. geographical area, a type of industry etc.).'
  Query.ZoneId:
    name: zoneId
    in: query
    description: Zone ID
    required: true
    type: string
      description: Used to get a list of identifiers for zones authorized for use by the application.
      produces:
        - application/json
      responses:
        '200':
          description: Successful response to a query regarding the status of a zone
          schema:
            properties:
              zoneList:
                $ref: '#/definitions/ZoneList'
          examples:
            application/json:
              zoneList:
                zone:
                  - zoneId: zone01
                    numberOfAccessPoints: '3'
                    numberOfUnserviceableAccessPoints: '1'
                    numberOfUsers: '10'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone01'
                  - zoneId: zone02
                    numberOfAccessPoints: '12'
                    numberOfUnserviceableAccessPoints: '0'
                    numberOfUsers: '36'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone02'
                resourceURL: 'http://example.com/exampleAPI/location/v1/zones'
  '/zones/{zoneId}':
    get:
      description: Used to get the status of a zone.
      produces:
        - application/json
      parameters:
        - $ref: '#/parameters/Path.ZoneId'
      responses:
        '200':
          description: Successful response to a query regarding the status of a zone
          schema:
            properties:
              zoneInfo:
                $ref: '#/definitions/ZoneInfo'
          examples:
            application/json:
              zoneInfo:
                zoneId: zone01
                numberOfAccessPoints: '3'
                numberOfUnserviceableAccessPoints: '1'
                numberOfUsers: '10'
                resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone01'
  '/zones/{zoneId}/accessPoints':
    get:
      description: Access point status can be retrieved for sets of access points matching attribute in the request.
        - $ref: '#/parameters/Path.ZoneId'
        - $ref: '#/parameters/Query.InterestRealm'
          description: Successful response to a query a named set of access point status request
                $ref: '#/definitions/AccessPointList'
          examples:
            application/json:
              accessPointList:
                zoneId: zone01
                accessPoint:
                  - accessPointId: '001010000000000000000000000000001'
                    locationInfo:
                      latitude: '90.123'
                      longitude: '80.123'
                      altitude: '10.0'
                      accuracy: '0'
                    connectionType: Macro
                    operationStatus: Serviceable
                    numberOfUsers: '5'
                    interestRealm: LA
                    resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone01/accessPoints/ap001'
                  - accessPointId: '001010000000000000000000000000010'
                    locationInfo:
                      latitude: '91.123'
                      longitude: '81.123'
                      altitude: '12.0'
                      accuracy: '1'
                    connectionType: Macro
                    operationStatus: Unserviceable
                    numberOfUsers: '0'
                    interestRealm: DC
                    resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone01/accessPoints/ap002'
                  - accessPointId: '001010000000000000000000000000011'
                    locationInfo:
                      latitude: '93.123'
                      longitude: '83.123'
                      altitude: '16.0'
                      accuracy: '3'
                    connectionType: Macro
                    operationStatus: Serviceable
                    numberOfUsers: '5'
                    interestRealm: NJ
                    resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone01/accessPoints/ap003'
                resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone01/accessPoints'
      description: Access point status can be retrieved for sets of access points matching attribute in the request.
        - $ref: '#/parameters/Path.ZoneId'
        - $ref: '#/parameters/Path.AccessPointId'
          description: Successful response to a query a named set of access point status request
                $ref: '#/definitions/AccessPointInfo'
          examples:
            application/json:
              accessPointInfo:
                accessPointId: '001010000000000000000000000000001'
                locationInfo:
                  latitude: '90.123'
                  longitude: '80.123'
                  altitude: '10.0'
                  accuracy: '0'
                connectionType: Macro
                operationStatus: Serviceable
                numberOfUsers: '5'
                interestRealm: LA
                resourceURL: 'http://example.com/exampleAPI/location/v1/zones/zone001/accessPoints/ap001'
      description: Users currently using a zone may be retrieved for sets of access points matching attribute in the request
        - $ref: '#/parameters/Query.ZoneId'
        - $ref: '#/parameters/Query.AccessPointId'
      responses:
        '200':
          description: Successful response to a query users within a zone request
          schema:
            properties:
              userList:
                $ref: '#/definitions/UserList'
          examples:
            application/json:
              userList:
                user:
                  - address: 'acr:192.0.2.1'
                    accessPointId: '001010000000000000000000000000001'
                    zoneId: zone01
                    resourceURL: 'http://example.com/exampleAPI/location/v1/users/acr%3A192.0.2.1'
                  - address: 'acr:192.0.2.2'
                    accessPointId: '001010000000000000000000000000001'
                    zoneId: zone01
                    resourceURL: 'http://example.com/exampleAPI/location/v1/users/acr%3A192.0.2.2'
                  - address: 'acr:192.0.2.3'
                    accessPointId: '001010000000000000000000000000010'
                    zoneId: zone01
                    resourceURL: 'http://example.com/exampleAPI/location/v1/users/acr%3A192.0.2.3'
                  - address: 'acr:192.0.2.4'
                    accessPointId: '001010000000000000000000000000001'
                    zoneId: zone02
                    resourceURL: 'http://example.com/exampleAPI/location/v1/users/acr%3A192.0.2.4'
                  - address: 'acr:192.0.2.5'
                    accessPointId: '001010000000000000000000000000010'
                    zoneId: zone02
                    resourceURL: 'http://example.com/exampleAPI/location/v1/users/acr%3A192.0.2.5'
                resourceURL: 'http://example.com/exampleAPI/location/v1/users'
  '/users/{userId}':
    get:
      description: Users currently using a zone may be retrieved for sets of access points matching attribute in the request
        - $ref: '#/parameters/Path.UserId'
      responses:
        '200':
          description: Successful response to a query users within a zone request
          schema:
            properties:
              userInfo:
                $ref: '#/definitions/UserInfo'
          examples:
            application/json:
              userInfo:
                address: 'acr:192.0.2.1'
                accessPointId: '001010000000000000000000000000001'
                zoneId: zone01
                resourceURL: 'http://example.com/exampleAPI/location/v1/users/acr%3A192.0.2.1'
                locationInfo:
                  latitude: '90.123'
                  longitude: '80.123'
                  altitude: '10.0'
                  accuracy: '0'
                contextLocationInfo: GroundFloor
  /subscriptions/zonalTraffic:
    get:
      description: This operation is used for retrieving all active subscriptions to zonal traffic change notifications.
      produces:
        - application/json
      responses:
        '200':
          description: Response to retrieve zonal traffic subscriptions
          schema:
            type: object
            properties:
              notificationSubscriptionList:
                type: object
                properties:
                  zonalTrafficSubscription:
                    type: array
                    items:
                      $ref: '#/definitions/ZonalTrafficSubscription'
                    $ref: '#/definitions/ResourceURL'
          examples:
            application/json:
              notificationSubscriptionList:
                zonalTrafficSubscription:
                  - clientCorrelator: '0123'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zonalTraffic/subscription123'
                      notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                    zoneId: zone01
                    interestRealm: LA
                    userEventCriteria: Transferring
                  - clientCorrelator: '0124'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zonalTraffic/subscription124'
                      notifyURL: 'http://clientApp.example.com/location_notifications/123457'
                    zoneId: zone02
                    interestRealm: LA
                    userEventCriteria: Transferring
                resourceURL: 'http://example.com/exampleAPI/location/v1/zonalTraffic'
    post:
      description: This operation is used for creating a new subscription to zonal traffic change notification.
        - $ref: '#/parameters/Body.ZonalTrafficSubscription'
      responses:
        '201':
          description: Response to create new zonal traffic subscription
          schema:
            properties:
              zonalTrafficSubscription:
                $ref: '#/definitions/ZonalTrafficSubscription'
          examples:
            application/json:
              zonalTrafficSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zonalTraffic/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                zoneId: zone01
                interestRealm: LA
                userEventCriteria: Transferring
  '/subscriptions/zonalTraffic/{subscriptionId}':
    get:
      description: This operation is used for updating an individual subscription to zonal traffic change notification.
        - $ref: '#/parameters/Path.SubscriptionId'
      responses:
        '200':
          description: Response to retrieve individual zonal traffic subscription
          schema:
            properties:
              zonalTrafficSubscription:
                $ref: '#/definitions/ZonalTrafficSubscription'
          examples:
            application/json:
              zonalTrafficSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zonalTraffic/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                zoneId: zone01
                interestRealm: LA
                userEventCriteria: Transferring
    put:
      description: This operation is used for updating an individual subscription to zonal traffic change notification.
        - $ref: '#/parameters/Path.SubscriptionId'
        - $ref: '#/parameters/Body.ZonalTrafficSubscription'
      responses:
        '200':
          description: Response to update individual zonal traffic subscription
          schema:
            properties:
              zonalTrafficSubscription:
                $ref: '#/definitions/ZonalTrafficSubscription'
          examples:
            application/json:
              zonalTrafficSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zonalTraffic/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                zoneId: zone01
                interestRealm: LA
                userEventCriteria: Transferring
    delete:
      description: This operation is used for cancelling a subscription and stopping corresponding notifications.
        - $ref: '#/parameters/Path.SubscriptionId'
      responses:
        '204':
          description: No content
  /subscriptions/userTracking:
    get:
      description: This operation is used for retrieving all active subscriptions to user tracking change notifications.
      produces:
        - application/json
      responses:
        '200':
          description: Response to retrieve user tracking subscriptions
          schema:
            type: object
            properties:
              notificationSubscriptionList:
                type: object
                properties:
                  userTrackingSubscription:
                    type: array
                    items:
                      $ref: '#/definitions/UserTrackingSubscription'
                    $ref: '#/definitions/ResourceURL'
          examples:
            application/json:
              notificationSubscriptionList:
                userTrackingSubscription:
                  - clientCorrelator: '0123'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/userTracking/subscription123'
                      notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                    address: 'acr:192.0.2.1'
                    userEventCriteria: Transferring
                  - clientCorrelator: '0124'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/userTracking/subscription124'
                      notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                    address: 'acr:192.0.2.2'
                    userEventCriteria: Transferring
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/userTracking'
      description: This operation is used for creating a new subscription to user tracking change notification
        - $ref: '#/parameters/Body.UserTrackingSubscription'
      responses:
        '201':
          description: Response to create new user tracking subscription
          schema:
            properties:
              userTrackingSubscription:
                $ref: '#/definitions/UserTrackingSubscription'
          examples:
            application/json:
              userTrackingSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/userTracking/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                address: 'acr:192.0.2.1'
                userEventCriteria: Transferring
  '/subscriptions/userTracking/{subscriptionId}':
    get:
      description: This operation is used for retrieving an individual subscription to user tracking change notification.
        - $ref: '#/parameters/Path.SubscriptionId'
      responses:
        '200':
          description: Response to retrieve individual user tracking subscription
          schema:
            properties:
              userTrackingSubscription:
                $ref: '#/definitions/UserTrackingSubscription'
          examples:
            application/json:
              userTrackingSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/userTracking/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                address: 'acr:192.0.2.1'
                userEventCriteria: Transferring
    put:
      description: This operation is used for updating an individual subscription to user tracking change notification.
        - $ref: '#/parameters/Path.SubscriptionId'
        - $ref: '#/parameters/Body.UserTrackingSubscription'
      responses:
        '200':
          description: Response to update individual user tracking subscription
          schema:
            properties:
              userTrackingSubscription:
                $ref: '#/definitions/UserTrackingSubscription'
          examples:
            application/json:
              userTrackingSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/userTracking/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                address: 'acr:192.0.2.1'
                userEventCriteria: Transferring
    delete:
      description: This operation is used for retrieving an individual subscription to user tracking change notification.
        - $ref: '#/parameters/Path.SubscriptionId'
      responses:
        '204':
          description: No Content
  /subscriptions/zonalStatus:
    get:
      description: This operation is used for creating a new subscription to zone status change notification.
      produces:
        - application/json
      responses:
        '200':
          description: Response to retrieve zone status subscriptions
          schema:
            type: object
            properties:
              notificationSubscriptionList:
                type: object
                properties:
                  zonalTrafficSubscription:
                    type: array
                    items:
                      $ref: '#/definitions/ZoneStatusSubscription'
                    $ref: '#/definitions/ResourceURL'
          examples:
            application/json:
              notificationSubscriptionList:
                zoneStatusSubscription:
                  - clientCorrelator: '0123'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zoneStatus/subscription123'
                      notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                    zoneId: zone01
                    numberOfUsersZoneThreshold: '500'
                    operationStatus: Serviceable
                  - clientCorrelator: '0124'
                    resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zoneStatus/subscription124'
                      notifyURL: 'http://clientApp.example.com/location_notifications/123457'
                    zoneId: zone02
                    numberOfUsersAPThreshold: '50'
                    operationStatus: Serviceable
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zoneStatus'
      description: This operation is used for creating a new subscription to zone status change notification.
        - $ref: '#/parameters/Body.ZoneStatusSubscription'
      responses:
        '201':
          description: Response to create new zone status subscription
          schema:
            properties:
              zonalTrafficSubscription:
                $ref: '#/definitions/ZoneStatusSubscription'
          examples:
            application/json:
              zoneStatusSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zoneStatus/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                zoneId: zone01
                numberOfUsersZoneThreshold: '500'
                operationStatus: Serviceable
  '/subscriptions/zoneStatus/{subscriptionId}':
    get:
      description: This operation is used for retrieving an individual subscription to zone status change notification.
        - $ref: '#/parameters/Path.SubscriptionId'
      responses:
        '200':
          description: Response to retrieve individual zone status subscription
          schema:
            properties:
              zoneStatusSubscription:
                $ref: '#/definitions/ZoneStatusSubscription'
          examples:
            application/json:
              zoneStatusSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zoneStatus/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                zoneId: zone01
                numberOfUsersZoneThreshold: '500'
                operationStatus: Serviceable
    put:
      description: This operation is used for updating an individual subscription to zone status change notification.
        - $ref: '#/parameters/Path.SubscriptionId'
        - $ref: '#/parameters/Body.ZoneStatusSubscription'
      responses:
        '200':
          description: Response to update individual zone status subscription
          schema:
            properties:
              zoneStatusSubscription:
                $ref: '#/definitions/ZoneStatusSubscription'
          examples:
            application/json:
              zoneStatusSubscription:
                clientCorrelator: '0123'
                resourceURL: 'http://example.com/exampleAPI/location/v1/subscriptions/zoneStatus/subscription123'
                callbackReference:
                  notifyURL: 'http://clientApp.example.com/location_notifications/123456'
                zoneId: zone01
                numberOfUsersZoneThreshold: '500'
                operationStatus: Serviceable
    delete:
      description: This operation is used for cancelling a subscription and stopping corresponding notifications.
      produces:
        - application/json
      parameters:
        - $ref: '#/parameters/Path.SubscriptionId'
      responses:
        '204':
          description: No content
    description: 'Identifier of access point, <E-CGI><Cell Portion ID> (reference ETSI TS 129 171). Where the E-CGI is made up of the PLMN and Cell Identity (28 bit string). Then the PLMN is made up of the 3 digit MCC & 2 or 3 digit MNC. The Cell Portion is an optional element'
    type: string
    example: '001010000000000000000000000000001'
  AccessPointInfo:
    description: A type containing access point information.
    type: object
    required:
      - accessPointId
      - connectionType
      - operationStatus
      - numberOfUsers
      - resourceURL
    properties:
      accessPointId:
        $ref: '#/definitions/AccessPointId'
        $ref: '#/definitions/LocationInfo'
        $ref: '#/definitions/ConnectionType'
        $ref: '#/definitions/OperationStatus'
        $ref: '#/definitions/NumberOfUsers'
        $ref: '#/definitions/Timezone'
        $ref: '#/definitions/InterestRealm'
        $ref: '#/definitions/ResourceURL'
    description: A type containing list of access points.
    type: object
        $ref: '#/definitions/ZoneId'
      accessPoint:
        description: Collection of the access point information list.
        type: array
        items:
          $ref: '#/definitions/AccessPointInfo'
        $ref: '#/definitions/ResourceURL'
  Address:
    description: 'Address of user (e.g. "sip" URI, "tel" URI, "acr" URI).'
    type: string
    format: uri
    example: 'acr:192.0.2.1'
  AncillaryInfo:
    description: Reserved for future use.
    type: string
    description: 'CallBackData if passed by the application during the associated ZonalTrafficSubscription and UserTrackingSubscription operation. See [REST_NetAPI_Common].'
    description: Notification callback definition.
    type: object
        $ref: '#/definitions/NotifyURL'
    description: 'Uniquely identifies this create subscription request. If there is a communication failure during the request, using the same clientCorrelator when retrying the request allows the operator to avoid creating a duplicate subscription.'
    type: string
    example: '0123'
  ConnectionType:
    description: The connection type for the access point
    type: string
    example: Macro
  ContextLocationInfo:
    description: 'Contextual information of a user location (e.g., aisle, floor, room number, etc.)'
    example: GroundFloor
  CurrentAccessPointId:
    description: Zone ID
    type: string
    example: zone01
  Duration:
    description: 'Period (in seconds) of time notifications are provided for. If set to "0" (zero), a default duration time, which is specified by the service policy, will be used. If the parameter is omitted, the notifications will continue until the maximum duration time, which is specified by the service policy, unless the notifications are stopped by deletion of subscription for notifications. This element MAY be given by the client during resource creation in order to signal the desired lifetime of the subscription. The server MUST return in this element the period of time for which the subscription will still be valid.'
    description: 'Interest realm of access point (e.g. geographical area, a type of industry etc.).'
    description: Link to other resources
    type: object
    required:
      - rel
      - href
    properties:
      rel:
        description: Describes the relationship between the URI and the resource.
        type: object
        format: string
      href:
        description: URI
        type: object
        format: anyURI
  LocationInfo:
    description: 'A type containing location information with latitude, longitude and altitude, in addition the accuracy of the information are provided.'
    type: object
    required:
      - latitude
      - longitude
      - accuracy
    properties:
      latitude:
        type: number
        format: float
        example: '80.123'
      longitude:
        type: number
        format: float
        example: '70.123'
      altitude:
        type: number
        format: float
        example: '10.0'
      accuracy:
        type: integer
        format: int32
        example: '10'
  NotifyURL:
    description: The URL of your own listener application.
    type: string
    format: url
    example: 'http://clientApp.example.com/location_notifications/123456'
  NumberOfAccessPoints:
    description: The number of access points within the zone
    type: integer
    format: uint32
    example: '10'
  NumberOfUnserviceableAccessPoints:
    description: Number of inoperable access points within the zone.
    type: integer
    format: uint32
    example: '9'
  NumberOfUsers:
    description: The number of users currently on the access point.
    type: integer
    format: uint32
    example: '7'
  NumberOfUsersAPThreshold:
    description: Threshold number of users in an access point which if crossed shall cause a notification.
    description: This element shall be present when ZoneStatusSubscription includes numberOfUsersAPThreshold element and the number of users in an access point exceeds the threshold defined in the subscription.
    description: This element shall be present when ZoneStatusSubscription includes numberOfUsersZoneThreshold element and the number of users in a zone exceeds the threshold defined in this subscription.
    type: integer
    format: uint32
    example: '20'
  NumberOfUsersZoneThreshold:
    description: Threshold number of users in a zone which if crossed shall cause a notification.
    type: integer
    format: uint32
    example: '40'
  OperationStatus:
    description: The operation status of the access point
    type: string
    example: Serviceable
  PreviousAccessPointId:
    description: Zone ID
    type: string
    example: zone02
  ResourceURL:
    description: Self referring URL.
    type: string
    format: uri
    example: 'http://example.com/exampleAPI/location/v1/subscriptions/userTracking/subscription123'
  Timestamp:
    description: Indicates the time of day for zonal presence notification.
    type: string
    format: date-time
    example: '2017-01-01T02:51:43Z'
  Timezone:
    description: Time zone of access point
    type: string
    format: date-time
    example: '2017-01-01T02:51:43Z'
  UserEventCriteria:
    description: 'List of user event values to generate notifications for (these apply to address specified). If this element is missing, a notification is requested to be generated for any change in user event.'
      $ref: '#/definitions/UserEventType'
  UserEventType:
    description: User event
    type: string
    example: Entering
  UserInfo:
    description: A type containing user information.
    type: object
    required:
      - address
      - accessPointId
      - zoneId
      - resourceURL
    properties:
      address:
        $ref: '#/definitions/Address'
        $ref: '#/definitions/AccessPointId'
        $ref: '#/definitions/ZoneId'
        $ref: '#/definitions/ResourceURL'
        $ref: '#/definitions/LocationInfo'
        $ref: '#/definitions/ContextLocationInfo'
        $ref: '#/definitions/AncillaryInfo'
  UserList:
    description: A type containing list of users.
    type: object
    required:
      - resourceURL
    properties:
      user:
        description: Collection of the zone information list.
        type: array
        items:
          $ref: '#/definitions/UserInfo'
        $ref: '#/definitions/ResourceURL'
    description: A type containing user tracking subscription.
    type: object
    required:
      - callbackReference
      - address
    properties:
      clientCorrelator:
        $ref: '#/definitions/ClientCorrelator'
        $ref: '#/definitions/CallbackReference'
        $ref: '#/definitions/Address'
        $ref: '#/definitions/UserEventCriteria'
        $ref: '#/definitions/ResourceURL'
    description: A type containing zonal presence notification
    type: object
    required:
      - zoneId
      - address
      - userEventType
      - currentAccessPointId
      - timestamp
    properties:
      callbackData:
        $ref: '#/definitions/CallbackData'
        $ref: '#/definitions/ZoneId'
        $ref: '#/definitions/Address'
        $ref: '#/definitions/InterestRealm'
        $ref: '#/definitions/UserEventType'
        $ref: '#/definitions/CurrentAccessPointId'
        $ref: '#/definitions/PreviousAccessPointId'
        $ref: '#/definitions/Timestamp'
        description: Link to other resources that are in relationship with this notification. The server SHOULD include a link to the related subscription. No other links are required or suggested by this specification.
          $ref: '#/definitions/Link'
        example: 'rel="ZonalTrafficSubscription" href="http://example.com/exampleAPI/location/v1/subscriptions/zonalTraffic/sub123"/'
  ZonalTrafficSubscription:
    description: A type containing zonal traffic subscription
    type: object
    required:
      - callbackReference
      - zoneId
    properties:
      clientCorrelator:
        $ref: '#/definitions/ClientCorrelator'
        $ref: '#/definitions/CallbackReference'
        $ref: '#/definitions/ZoneId'
        description: 'Interest realms of access points within a zone (e.g. geographical area, a type of industry etc.).'
          $ref: '#/definitions/InterestRealm'
        description: 'List of user event values to generate notifications for (these apply to zone identifier or all interest realms within zone identifier specified). If this element is missing, a notification is requested to be generated for any change in user event.'
          $ref: '#/definitions/UserEventType'
        $ref: '#/definitions/Duration'
        $ref: '#/definitions/ResourceURL'
  ZoneId:
    description: Identifier of zone
    type: string
    example: zone01
  ZoneInfo:
    description: A type containing zone information.
    type: object
    required:
      - zoneId
      - numberOfAccessPoints
      - numberOfUnservicableAccessPoints
      - numberOfUsers
      - resourceURL
    properties:
      zoneId:
        $ref: '#/definitions/ZoneId'
        $ref: '#/definitions/NumberOfAccessPoints'
        $ref: '#/definitions/NumberOfUnserviceableAccessPoints'
        $ref: '#/definitions/NumberOfUsers'
        $ref: '#/definitions/ResourceURL'
  ZoneList:
    description: Collection of the zone information list.
    type: object
    required:
      - resourceURL
    properties:
      zone:
        description: Collection of the zone information list.
        type: array
        items:
          $ref: '#/definitions/ZoneInfo'
        $ref: '#/definitions/ResourceURL'
    description: A type containing zone status notification.
    type: object
        $ref: '#/definitions/CallbackData'
        $ref: '#/definitions/ZoneId'
        $ref: '#/definitions/AccessPointId'