Searching...

Matching results

    Company

    Represents a business organization in the AirVantage terminology. Almost all entities are associated with a company.

    Read only fields are computed in AirVantage and can only be seen on response fragments sent by details or edit requests.

    Field Description Read Only Type
    uid Company's unique identifier. true uid
    name Company's name. Must be unique throughout AirVantage. false string
    address The address of this company. false string
    nFactor Says whether the 2-factor authentication is activated for this company or not. true boolean
    ipFiltering Says whether API requests for resources of this company are filtered or not. false boolean
    ipFilters.startIPAddress This field specifies the beginning of the IP range filter. It is related to endIPAddress field. false string
    ipFilters.endIPAddress This field specifies the ending of the IP range filter. It is related to startIPAddress field. false string
    ipFilters.ipAddresses List of acceptable IP addresses. false string list
    deviceIpFiltering Says whether device communications of this company are filtered or not. false boolean
    deviceIpFilters.startIPAddress This field specifies the beginning of the IP range filter. It is related to endIPAddress field. false string
    deviceIpFilters.endIPAddress This field specifies the ending of the IP range filter. It is related to startIPAddress field. false string
    deviceIpFilters.ipAddresses List of acceptable IP addresses. false string list
    picture References to a picture in three different sizes:
    - Normal: keeps original image.
    - Small : resized image to 32x32 pixels keeping the length/width ratio.
    - icon : resized image to 16x16 pixels keeping the original length/width ratio.
    true string

    This is a complete representation of a Company. This fragment can be used for edit request. Please refer to the fields section to know which fields can be modified.

    {
       "uid": "",
       "address": "",
       "name": "",
       "nFactor": false,
       "ipFiltering": true,
       "ipFilters" : {
        "startIPAddress" : "10.41.51.0", 
        "endIPAddress" : "10.41.51.30", 
        "ipAddresses" : ["10.41.51.255"]
       },
       "deviceIpFiltering":false,
       "deviceIpFilters" : {
        "startIPAddress":null,
        "endIPAddress":null,
        "ipAddresses":[]
       }
    }

    /api/v1/company/{uid}

    Returns detailed information about the specified company.

    Request

    GET https://na.airvantage.net/api/v1/company/1

    Response
    200 OK

    HTTP/1.1 200 OK
    Content-Type: application/json
    ...
    {
       "uid": "1",
       "picture":    {
          "normal": "/company/1/picture/normal",
          "small": "/company/1/picture/small",
          "icon": "/company/1/picture/icon"
       },
       "address": "Lake Park",
       "name": "Sierra Wireless",
       "nFactor" : false
    }
    Name Description
    company.unknown The specified uid does not match with any existing company.
    HTTP Method GET
    Requires Authentication Yes
    Rate Limited Yes
    Headers None
    Permissions accountNetwork.company.viewDetails

    /api/v1/company/{uid}

    Edits details of a company. Only name, address, ipFiltering, ipFilters, deviceIpFiltering and deviceIpFilters fields can be updated.

    Request

    PUT https://na.airvantage.net/api/v1/company/a473d07f165048878c2678f362770a59
    Content-Type: application/json
    ...
    // with the following content
    {
       "name" : "New Company Name",
       "address" : "New address"
    }

    Response
    200 OK

    ...
    {
       "name" : "New Company Name",
    }
    Name Description
    company.unknown The specified uid does not match with any existing company.
    company.missing.name Trying to set name field to null.
    company.not.unique.name The specified name is already set to another company.
    value.too.long The specified address exceed 255 characters.
    company.missing.ip.address.filtering Missing IP filters when the company is updated with ip filtering to true.
    company.invalid.ip.address A specified IP address is not well formated.
    company.invalid.ip.address.range The specified IP range is invalid. For example, end IP address is missing when start address was given. Or beginning is bigger than the end.
    company.missing.device.ip.address.filtering Missing IP filters when the company is updated with device ip filtering to true.
    company.invalid.device.ip.address A specified device IP address is not well formated.
    company.invalid.device.ip.address.range The specified device IP range is invalid. For example, end IP address is missing when start address was given. Or beginning is bigger than the end.
    HTTP Method PUT
    Requires Authentication Yes
    Rate Limited Yes
    Headers Content-type: application/json
    Permissions administrator

    /api/v1/company/{uid}/administrators

    Gets the administrators of the given company.

    Request

    GET https://na.airvantage.net/api/v1/company/a473d07f165048878c2678f362770a59/administrators

    Response
    200 OK

    HTTP/1.1 200 OK
    Content-Type: application/json
    ...
    [
    {
       "uid": "79e40bf47bcd44de93352fc72918fa20",
       "company" : {
            "uid": "a473d07f165048878c2678f362770a59"
       }
       "email": "admin1@airvantage.net",
       "name": "Admin 1"
    },
    {
       "uid": "5cd44bfb5dd14385885e9037866bf823",
       "company" : {
            "uid": "a473d07f165048878c2678f362770a59"
       }
       "email": "admin2@airvantage.net",
       "name": "Admin 2"
    }
    ]
    Name Description
    company.unknown The specified uid does not match with any existing company.
    HTTP Method GET
    Requires Authentication Yes
    Rate Limited Yes
    Headers None
    Permissions accountNetwork.company.viewAdministrators

    /api/v1/company/{uid}/administrators

    Sets a new list of administrators of a specific company. In other words, if you want to add a user to the exisiting list of administrator, then you have to send this list extended with the uid of the new user. Notices that it is not possible to send an empty list. At least one administrator must be set.

    Request

    PUT https://na.airvantage.net/api/v1/company/a473d07f165048878c2678f362770a59/administrators
    Content-Type: application/json
    ...
    {
       "administrators" : [{"uid" : "79e40bf47bcd44de93352fc72918fa20"}, {"uid" : "5cd44bfb5dd14385885e9037866bf823"}]
    }

    Response
    200 OK

    HTTP/1.1 200 OK
    Content-Type: application/json
    ...
    [
    {
       "uid": "79e40bf47bcd44de93352fc72918fa20",
       "company" : {
            "uid": "a473d07f165048878c2678f362770a59"
       }
       "email": "admin1@airvantage.net",
       "name": "Admin 1"
    },
    {
       "uid": "5cd44bfb5dd14385885e9037866bf823",
       "company" : {
             "uid": "a473d07f165048878c2678f362770a59"
       }
       "email": "admin2@airvantage.net",
       "name": "Admin 2"
    }
    ]
    Name Description
    company.unknown The specified uid does not match with any existing company.
    user.unknown Raised when a specified user in the administrator list does not exist in the company.
    user.missing Raised when an empty list were sent.
    admin.without.profile A user without profile cannot be removed from the administrator list.
    HTTP Method PUT
    Requires Authentication Yes
    Rate Limited Yes
    Headers None
    Permissions administrator

    /api/v1/company/{uid}/picture/{name}

    Gets the company image in a specific size: original size, thumbnail size, or icon size.

    Request

    GET https://na.airvantage.net/api/v1/company/1/picture/small
    ...

    Response
    200 OK

                                
    Name Description
    company.unknown The specified uid does not match with any existing company.
    company.file.not.found The requested image does not exist.
    HTTP Method GET
    Requires Authentication Yes
    Rate Limited Yes
    Headers None
    Permissions accountNetwork.company.viewDetails

    /api/v1/company/{uid}/picture

    Uploads an image. The service creates 3 images in the file store for the uploaded one.

    Uploaded images cannot be bigger than 750KB and dimensions have to be equals or less than 1024 px per side.

    Request

    POST https://na.airvantage.net/api/v1/companies/1/picture
    Content-Type: image/jpeg
    
    // with an attached jpeg file
    ...

    Response
    200 OK

    HTTP/1.1 200 OK
    Name Description
    company.unknown The specified uid does not match with any existing company.
    invalid.format Expected formats are JPG or PNG.
    image.invalid.dimension Images cannot have more than 1024 px per side.
    file.too.large Images cannot be more than 750KB.
    HTTP Method POST
    Requires Authentication Yes
    Rate Limited Yes
    Headers Content-type: image/jpeg||png)
    Permissions administrator
    TOP