REST API Docs
You can use our REST API to fetch and query your VPS Maps to get device Pose with respect to Map local origin, the query API takes query image (encoded as a base64 string) and other image metadata.
Note: you will need to contact MultiSet Team before using this api's to approve your domain and avoid CORS issue
M2M Auth
Authenticates a machine-to-machine client using Basic Authentication and returns an access token. The Basic Auth value should be constructed as: Base64(clientId:clientSecret)
Client ID for authentication
Client Secret for authentication
Basic authentication header. Format: "Basic " + Base64(clientId:clientSecret)
Basic dXNlcm5hbWU6cGFzc3dvcmQ=Token generated successfully
Bad request
Unauthorized
Forbidden
POST /v1/m2m/token HTTP/1.1
Host: api.multiset.ai
Authorization: text
Username: text
Password: text
Content-Type: text/plain
Accept: */*
{
"token": "eyJhbGciOiJIUzI1NiIsInR5cC.......",
"expiresOn": "2024-10-22T18:40:54.908Z"
}GET All VPS maps for an account
Retrieves a paginated list of VPS maps using limit and page parameters
Number of items to return per page
10Example: 10Page number for pagination
1Example: 1VPS maps retrieved successfully
Unauthorized
GET /v1/vps/map HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Accept: */*
{
"data": [
{
"id": "66ca3f3b773b18f09e131279",
"name": "Office Building Map",
"description": "3D map of the main office building",
"createdAt": "2024-01-15T10:30:00.000Z",
"updatedAt": "2024-01-15T10:30:00.000Z",
"status": "active"
}
],
"pagination": {
"totalItems": 45,
"totalPages": 5,
"currentPage": 1,
"itemsPerPage": 10
}
}Permanently deletes a VPS map identified by its unique ID
The unique ID of the VPS map to delete
66ca3f3b773b18f09e131279VPS map deleted successfully
No content
Bad Request - Invalid map ID format
Unauthorized
Map not found
Internal Server Error - Something went wrong on the server
DELETE /v1/vps/map/{mapId} HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Accept: */*
No content
VPS Query API
Query your map to get the device position with respect to Map local origin, the query API takes query image (encoded as base64 string) and other image metadata
Unique identifier for the VPS map
MAP-X2P23E7Q35VDFlag to indicate if response pose is in right-handed coordinate system
falseBase64 encoded image data
 successful
Bad request
Unauthorized
POST /v1/vps/map/query HTTP/1.1
Host: api.mulitset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Content-Type: application/json
Accept: */*
Content-Length: 388
{
"mapCode": "MAP-X2P23E7Q35VD",
"cameraIntrinsics": {
"fx": 664.3856201171875,
"fy": 664.3856201171875,
"px": 478.9782409667969,
"py": 364.9932861328125
},
"isRightHanded": false,
"resolution": {
"width": 960,
"height": 720
},
"queryImage": ""
}{
"poseFound": true,
"position": {
"x": 2.482360321597187,
"y": 0.11936171927197065,
"z": 8.06609995252609
},
"rotation": {
"x": 0.02949315565629783,
"y": 0.7673793569590026,
"z": -0.01740867960782986,
"w": 0.6402780756491143
},
"confidence": 0.459232334365416
}VPS Query Form API
The map code for the map to query (required if mapSetCode is not provided)
The map set code for the map set to query (required if mapCode is not provided)
truePossible values: 669.535888671875669.535888671875478.8777160644531364.9244079589844960720Image file for multipart requests
Query successful
Successful query response (structure to be defined)
Bad request
Unauthorized
POST /v1/vps/map/query-form HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Content-Type: multipart/form-data
Accept: */*
Content-Length: 210
{
"mapCode": "text",
"mapSetCode": "text",
"isRightHanded": "true",
"fx": "669.535888671875",
"fy": "669.535888671875",
"px": "478.8777160644531",
"py": "364.9244079589844",
"width": "960",
"height": "720",
"queryImage": "binary"
}{}VPS Multi Image Query API
Multi-image query API requires a minimum of 4 images in each request. Up to 6 images can be passed. Higher image counts increase localization robustness and accuracy but may compromise latency.
Performs a query using one or more uploaded images, along with camera intrinsics and optional map or map-set identifiers. Supports up to four images in a single request.
Specifies whether the coordinate system is right-handed. Because this is form-data, it's sent as a string ("true" or "false").
truePossible values: The width (in pixels) of the input image(s).
960The height (in pixels) of the input image(s).
720The principal point x-coordinate.
478.838623046875The principal point y-coordinate.
365.346618652343The focal length along x-axis.
670.4620971679688The focal length along y-axis.
670.4620971679688ID of the specific map.
Code to identify the map.
A unique ID for the map set.
A code to identify the map set.
The first image file to be uploaded.
JSON-encoded metadata for image1 (e.g., position and rotation).
{"x":-5.1772,"y":0.2936,"z":-2.6439,"qx":-0.0185,"qy":0.9949,"qz":-0.0691,"qw":0.0703}The second image file to be uploaded.
JSON-encoded metadata for image2.
{"x":-3.12,"y":1.01,"z":2.56,"qx":0.0,"qy":0.707,"qz":0.0,"qw":0.707}The third image file to be uploaded.
JSON-encoded metadata for image3.
{"x":1.23,"y":-0.56,"z":5.0,"qx":-0.0185,"qy":0.9949,"qz":-0.0691,"qw":0.0703}The fourth image file to be uploaded.
JSON-encoded metadata for image4.
{"x":10.0,"y":-2.0,"z":0.0,"qx":0.0,"qy":1.0,"qz":0.0,"qw":0.0}Query successful
Bad request
Unauthorized - Missing or invalid token
Map/MapSet not found (if applicable)
Internal server error
POST /v1/vps/map/multi-image-query HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Content-Type: multipart/form-data
Accept: */*
Content-Length: 697
{
"isRightHanded": "true",
"width": "960",
"height": "720",
"px": "478.838623046875",
"py": "365.346618652343",
"fx": "670.4620971679688",
"fy": "670.4620971679688",
"mapId": "",
"mapCode": "",
"mapSetId": "",
"mapSetCode": "",
"image1": "binary",
"image1_data": "{\"x\":-5.1772,\"y\":0.2936,\"z\":-2.6439,\"qx\":-0.0185,\"qy\":0.9949,\"qz\":-0.0691,\"qw\":0.0703}",
"image2": "binary",
"image2_data": "{\"x\":-3.12,\"y\":1.01,\"z\":2.56,\"qx\":0.0,\"qy\":0.707,\"qz\":0.0,\"qw\":0.707}",
"image3": "binary",
"image3_data": "{\"x\":1.23,\"y\":-0.56,\"z\":5.0,\"qx\":-0.0185,\"qy\":0.9949,\"qz\":-0.0691,\"qw\":0.0703}",
"image4": "binary",
"image4_data": "{\"x\":10.0,\"y\":-2.0,\"z\":0.0,\"qx\":0.0,\"qy\":1.0,\"qz\":0.0,\"qw\":0.0}"
}{
"success": true,
"location": {
"position": {
"x": -5.1772,
"y": 0.2936,
"z": -2.6439
},
"rotation": {
"qx": -0.0185,
"qy": 0.9949,
"qz": -0.0691,
"qw": 0.0703
}
},
"confidence": 0.89,
"mapId": "66ca3f3b773b18f09e131279"
}ModelSet Query API
Query a VPS object using an uploaded image and camera parameters. Accepts objectCode to identify the target object, and returns the query result from the external API.
The code of the VPS object
OBJ-001Camera intrinsic parameter fx (focal length x-axis)
1000.0Camera intrinsic parameter fy (focal length y-axis)
1000.0Camera intrinsic parameter px (principal point x-coordinate)
640.0Camera intrinsic parameter py (principal point y-coordinate)
480.0Specifies whether the coordinate system is right-handed. Because this is form-data, it's sent as a string ("true" or "false").
truePossible values: The width (in pixels) of the input image
1280The height (in pixels) of the input image
720The image file to query against the object
Query successful
Bad request - Invalid parameters or missing required fields
Unauthorized - Missing or invalid token
Forbidden - Access denied
Object not found
Internal server error
POST /v1/vps/object/query HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Content-Type: multipart/form-data
Accept: */*
Content-Length: 153
{
"objectCode": "OBJ-001",
"fx": "1000.0",
"fy": "1000.0",
"px": "640.0",
"py": "480.0",
"isRightHanded": "true",
"width": "1280",
"height": "720",
"queryImage": "binary"
}{
"success": true,
"result": {
"position": {
"x": 2.1234,
"y": 1.5678,
"z": 0.9876
},
"rotation": {
"qx": 0.0123,
"qy": 0.4567,
"qz": 0.0789,
"qw": 0.8901
},
"confidence": 0.92
},
"message": "Query successful."
}File download API
Generates a temporary, pre-signed URL for downloading a file from S3
Unique identifier for the file
671b454e33d6dc761ca15156/6756c20336a9794c6effce42/Mesh/TexturedMesh.glbSuccessfully generated pre-signed URL
Unauthorized - Invalid or expired token
File not found
Server error
GET /v1/file?key=text HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Accept: */*
{
"url": "https://amazonaws.com/671bX-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential=%2Faws4_request&X-Amz-Date=20241658753a8c6380ad6d01c217e1ad978d88e2ba6a4&X-Amz-SignedHeaders=host&x-id=GetObject"
}APIs to Get MapSet (merged maps)
Get the list of all Mapsets in an account
Retrieves a paginated list of MapSets associated with the authenticated user's account
Number of items to return per page
10Example: 10Page number for pagination
1Example: 1MapSets retrieved successfully
Bad Request - Invalid parameters
Unauthorized
Internal Server Error - Something went wrong on the server
GET /v1/vps/map-set HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Accept: */*
{
"data": [
{
"id": "66ca3f3b773b18f09e131280",
"name": "Office Buildings Collection",
"description": "Collection of office building maps",
"createdAt": "2024-01-15T10:30:00.000Z",
"updatedAt": "2024-01-15T10:30:00.000Z",
"status": "active",
"mapCount": 3
}
],
"pagination": {
"totalItems": 12,
"totalPages": 2,
"currentPage": 1,
"itemsPerPage": 10
}
}Get details of all maps of a specific Mapset using MapSetID
Fetches details of a specific map set using its unique ID.
The unique ID of the map set.
67a5c7fca18f6052c5b21653Map set details retrieved successfully
Invalid map set ID
Unauthorized - Authorization header missing or invalid
Map set not found
Internal server error
GET /v1/vps/map-set/{mapSetId} HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Accept: */*
{
"mapSet": {
"_id": "67a5c7fca18f6052c5b21653",
"name": "purva test new 141",
"accountId": "67192b1b65071c55d950d11f",
"mapSetCode": "MSET_7J7SUEFVMSV1",
"status": "active",
"messages": [],
"createdAt": "2025-02-07T08:44:44.607Z",
"updatedAt": "2025-02-07T08:44:44.607Z",
"mapSetData": [
{
"_id": "67a5c7fc58eda5c8bfaedc2e",
"createdAt": "2025-02-07T08:44:44.614Z",
"order": 0,
"relativePose": {
"position": {
"x": 0,
"y": 0,
"z": 0
},
"rotation": {
"qx": 0,
"qy": 0,
"qz": 0,
"qw": 1
}
},
"updatedAt": "2025-02-07T08:44:44.614Z",
"map": {
"_id": "67a4a02ba18f6052c5b20833",
"accountId": "67192b1b65071c55d950d11f",
"mapName": "141",
"status": "active",
"storage": 66.59728527069092,
"mapCode": "MAP_XCQWQYKZ26U2",
"createdAt": "2025-02-06T11:42:35.504Z",
"updatedAt": "2025-02-07T08:44:44.620Z",
"mapMesh": {
"rawMesh": {
"type": "glb",
"meshLink": "67192b150d11f/67a4a02b5b20833/Mesh/Mesh.glb"
},
"texturedMesh": {
"type": "glb",
"meshLink": "67192b1b6d11f/67a4a02ba2c5b20833/Mesh/TexturedMesh.glb"
}
},
"thumbnail": "67192b10d11f/67a4a022c833/RGB/Rgb_20250206114139457.jpg",
"coordinates": {
"latitude": 22.89059543609619,
"longitude": 57.63724517822266,
"altitude": 901.3638305664062
}
}
}
]
}
}Retrieves a paginated list of VPS objects. You can use query parameters to filter or search objects by name, and control pagination settings.
The page number for pagination (starting from 1)
1Example: 1Number of records per page (maximum 100)
10Example: 10Filter or search text for partial match on object names
MultisetA paginated list of VPS objects retrieved successfully
Bad request - Invalid query parameters
Unauthorized - Missing or invalid token
Internal server error
GET /v1/vps/object HTTP/1.1
Host: api.multiset.ai
Authorization: Bearer YOUR_SECRET_TOKEN
Accept: */*
{
"data": [
{
"_id": "67a5b08736cb3f76aaf3a416",
"objectName": "Multiset Object 1",
"trackingType": "side",
"source": {
"provider": "web",
"fileType": "glb",
"coordinateSystem": "RHS"
}
},
{
"_id": "67a5b08736cb3f76aaf3a417",
"objectName": "Multiset Object 2",
"trackingType": "top",
"source": {
"provider": "mobile",
"fileType": "obj",
"coordinateSystem": "LHS"
}
}
],
"currentPage": 1,
"totalPages": 5,
"totalCount": 42
}Last updated
Was this helpful?