Skip to main content
POST
/
api
/
v1
/
workspaces
Create workspace
curl --request POST \
  --url https://api.luxxon.dev/api/v1/api/v1/workspaces \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "slug": "acme",
  "name": "Acme Visuals",
  "walletAddress": "0xAbC0000000000000000000000000000000000001",
  "signature": "0x1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0c1d2e3f4a5b6c7d8e9f0a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0c1d2e3f4a5b6c7d8e9f0a1b",
  "nonce": "9f3a2b1c0d4e5f6a7b8c9d0e1f2a3b4c",
  "roles": [
    "CONSUMER"
  ]
}
'
{
  "statusCode": 200,
  "message": "Request successful",
  "data": {
    "id": "8c3a5b6f-1d2e-4f7a-9b8c-d1e2f3a4b5c6",
    "slug": "acme",
    "name": "Acme Visuals",
    "walletAddress": "0xAbC0000000000000000000000000000000000001",
    "roles": [
      "CONSUMER"
    ],
    "availabilityState": "OFFLINE",
    "coverageLat": 4.711,
    "coverageLng": -74.07,
    "coverageRadiusMeters": 500,
    "deviceKind": "PHONE",
    "lastSeenAt": null,
    "createdAt": "2026-05-13T11:30:00.000Z",
    "createdByWallet": "0xAbC0000000000000000000000000000000000001",
    "deletedAt": null,
    "consistencyToken": "GgEAAAAA..."
  },
  "timestamp": "2026-05-13T12:00:00.000Z"
}

Authorizations

Authorization
string
header
required

Bearer authentication header of the form Bearer <token>, where <token> is your auth token.

Body

application/json
slug
string
required

URL slug. lowercase alphanumeric + hyphen, 3–40 chars.

Example:

"acme"

name
string
required
Example:

"Acme Visuals"

walletAddress
string
required
Example:

"0xAbC0000000000000000000000000000000000001"

signature
string
required

Signature over the challenge message from POST /challenge.

Example:

"0x1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0c1d2e3f4a5b6c7d8e9f0a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0c1d2e3f4a5b6c7d8e9f0a1b"

nonce
string
required
Example:

"9f3a2b1c0d4e5f6a7b8c9d0e1f2a3b4c"

roles
enum<string>[]
required
Available options:
CONSUMER,
SUPPLIER
Example:
["CONSUMER"]

Response

Request successful

statusCode
number
required
Example:

200

message
string
required
Example:

"Request successful"

data
object
required

Endpoint-specific payload. See the per-endpoint schema.

timestamp
string
required
Example:

"2026-05-13T12:00:00.000Z"