Bulk add keys to a lock via workflow
Starts a Cloudflare Workflow that adds multiple keys to a lock. Keys are added sequentially with a 1-second delay between commands. Each key addition is a durable step that retries on failure.
curl -X POST "https://api.spkey.co/locks/123/BulkAddKeys" \
-H "Content-Type: application/json" \
-H "Authorization: Bearer YOUR_API_TOKEN (JWT)" \
-H "X-API-Key: YOUR_API_KEY" \
-d '{
"keys": [
{
"keyUuid": "example_string",
"keyIndexNumber": 42,
"userId": "example_string"
}
]
}'
import requests
import json
url = "https://api.spkey.co/locks/123/BulkAddKeys"
headers = {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN (JWT)",
"X-API-Key": "YOUR_API_KEY"
}
data = {
"keys": [
{
"keyUuid": "example_string",
"keyIndexNumber": 42,
"userId": "example_string"
}
]
}
response = requests.post(url, headers=headers, json=data)
print(response.json())
const response = await fetch("https://api.spkey.co/locks/123/BulkAddKeys", {
method: "POST",
headers: {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN (JWT)",
"X-API-Key": "YOUR_API_KEY"
},
body: JSON.stringify({
"keys": [
{
"keyUuid": "example_string",
"keyIndexNumber": 42,
"userId": "example_string"
}
]
})
});
const data = await response.json();
console.log(data);
package main
import (
"fmt"
"net/http"
"bytes"
"encoding/json"
)
func main() {
data := []byte(`{
"keys": [
{
"keyUuid": "example_string",
"keyIndexNumber": 42,
"userId": "example_string"
}
]
}`)
req, err := http.NewRequest("POST", "https://api.spkey.co/locks/123/BulkAddKeys", 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/locks/123/BulkAddKeys')
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 = '{
"keys": [
{
"keyUuid": "example_string",
"keyIndexNumber": 42,
"userId": "example_string"
}
]
}'
response = http.request(request)
puts response.body
{
"success": true,
"lockId": 3.14,
"instanceId": "example_string"
}
{
"error": "Unauthorized",
"message": "Authentication required. Please provide a valid API token",
"code": 401
}
/locks/{id}/BulkAddKeysTarget 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.
Lock ID (numeric)
The media type of the request body
List of keys to add to the lock
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
Lock ID (numeric)
Body
List of keys to add to the lock
Responses
false