Claim hub
Claims a provisioned hub and binds it to Organization and Site
curl -X POST "https://api.spkey.co/hubs/example_string/ClaimHub" \
-H "Content-Type: application/json" \
-H "Authorization: Bearer YOUR_API_TOKEN (JWT)" \
-H "X-API-Key: YOUR_API_KEY" \
-d '{
"hubId": "example_string",
"orgId": "example_string",
"siteId": "example_string",
"userId": "example_string"
}'
import requests
import json
url = "https://api.spkey.co/hubs/example_string/ClaimHub"
headers = {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN (JWT)",
"X-API-Key": "YOUR_API_KEY"
}
data = {
"hubId": "example_string",
"orgId": "example_string",
"siteId": "example_string",
"userId": "example_string"
}
response = requests.post(url, headers=headers, json=data)
print(response.json())
const response = await fetch("https://api.spkey.co/hubs/example_string/ClaimHub", {
method: "POST",
headers: {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN (JWT)",
"X-API-Key": "YOUR_API_KEY"
},
body: JSON.stringify({
"hubId": "example_string",
"orgId": "example_string",
"siteId": "example_string",
"userId": "example_string"
})
});
const data = await response.json();
console.log(data);
package main
import (
"fmt"
"net/http"
"bytes"
"encoding/json"
)
func main() {
data := []byte(`{
"hubId": "example_string",
"orgId": "example_string",
"siteId": "example_string",
"userId": "example_string"
}`)
req, err := http.NewRequest("POST", "https://api.spkey.co/hubs/example_string/ClaimHub", bytes.NewBuffer(data))
if err != nil {
panic(err)
}
req.Header.Set("Content-Type", "application/json")
req.Header.Set("Authorization", "Bearer YOUR_API_TOKEN (JWT)")
req.Header.Set("X-API-Key", "YOUR_API_KEY")
client := &http.Client{}
resp, err := client.Do(req)
if err != nil {
panic(err)
}
defer resp.Body.Close()
fmt.Println("Response Status:", resp.Status)
}
require 'net/http'
require 'json'
uri = URI('https://api.spkey.co/hubs/example_string/ClaimHub')
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = true
request = Net::HTTP::Post.new(uri)
request['Content-Type'] = 'application/json'
request['Authorization'] = 'Bearer YOUR_API_TOKEN (JWT)'
request['X-API-Key'] = 'YOUR_API_KEY'
request.body = '{
"hubId": "example_string",
"orgId": "example_string",
"siteId": "example_string",
"userId": "example_string"
}'
response = http.request(request)
puts response.body
{
"success": true,
"aggregateId": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
"version": 2
}
{
"error": "Bad Request",
"message": "The request contains invalid parameters or malformed data",
"code": 400,
"details": [
{
"field": "email",
"message": "Invalid email format"
}
]
}
{
"error": "Not Found",
"message": "The requested resource was not found",
"code": 404
}
{
"error": "Error",
"message": "Hub offline — the hub is not currently connected to the network.",
"code": 502
}
/hubs/{id}/ClaimHubTarget server for requests. Edit to use your own host.
JWT token from SmartphoneKey authentication. Identifies the B2C user or B2B service.
API key for B2B organization access. Provided during organization onboarding.
Hub ID
The media type of the request body
Hub ID
Organization ID. Normal keys: bound from the authenticated key — a mismatching value is rejected (403); omit it to claim into your own org. Super keys only: may set any org for a cross-org claim.
Site ID
User ID claiming the hub
Request Preview
Response
Response will appear here after sending the request
Authentication
Bearer token (JWT). JWT token from SmartphoneKey authentication. Identifies the B2C user or B2B service.
API Key for authentication. API key for B2B organization access. Provided during organization onboarding.
Path Parameters
Hub ID
Body
Hub ID
Organization ID. Normal keys: bound from the authenticated key — a mismatching value is rejected (403); omit it to claim into your own org. Super keys only: may set any org for a cross-org claim.
Site ID
User ID claiming the hub
Responses
falsefalsefalse