import {HeroPattern} from "@/components/HeroPattern"; import {Note} from "@/components/mdx"; ## List all Setup Keys {{ tag: 'GET' , label: '/api/setup-keys' }} Returns a list of all Setup Keys ```bash {{ title: 'cURL' }} curl -X GET https://api.netbird.io/api/setup-keys \ -H "Authorization: Token " \ -H 'Accept: application/json' \ ``` ```js const axios = require('axios'); let config = { method: 'get', maxBodyLength: Infinity, url: '/api/setup-keys', headers: { 'Accept': 'application/json', 'Authorization': 'Token ' } }; axios(config) .then((response) => { console.log(JSON.stringify(response.data)); }) .catch((error) => { console.log(error); }); ``` ```python import requests import json url = "https://api.netbird.io/api/setup-keys" headers = { 'Accept': 'application/json', 'Authorization': 'Token ' } response = requests.request("GET", url, headers=headers) print(response.text) ``` ```go package main import ( "fmt" "strings" "net/http" "io/ioutil" ) func main() { url := "https://api.netbird.io/api/setup-keys" method := "GET" client := &http.Client { } req, err := http.NewRequest(method, url, nil) if err != nil { fmt.Println(err) return } req.Header.Add("Accept", "application/json") req.Header.Add("Authorization", "Token ") res, err := client.Do(req) if err != nil { fmt.Println(err) return } defer res.Body.Close() body, err := ioutil.ReadAll(res.Body) if err != nil { fmt.Println(err) return } fmt.Println(string(body)) } ``` ```ruby require "uri" require "json" require "net/http" url = URI("https://api.netbird.io/api/setup-keys") https = Net::HTTP.new(url.host, url.port) https.use_ssl = true request = Net::HTTP::Post.new(url) request["Accept"] = "application/json" request["Authorization"] = "Token " response = https.request(request) puts response.read_body ``` ```java OkHttpClient client = new OkHttpClient().newBuilder() .build(); MediaType mediaType = MediaType.parse("application/json"); RequestBody body = RequestBody.create(mediaType, ''); Request request = new Request.Builder() .url("https://api.netbird.io/api/setup-keys") .method("GET", body) .addHeader("Accept", "application/json") .addHeader("Authorization: Token ") .build(); Response response = client.newCall(request).execute(); ``` ```php 'https://api.netbird.io/api/setup-keys', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'GET', CURLOPT_POSTFIELDS =>'', CURLOPT_HTTPHEADER => array( 'Accept: application/json', 'Authorization: Token ' ), )); $response = curl_exec($curl); curl_close($curl); echo $response; ``` ```json {{ title: '200' }} [ { "id": "string", "key": "string", "name": "string", "expires": "string", "type": "string", "valid": "boolean", "revoked": "boolean", "used_times": "integer", "last_used": "string", "state": "string", "auto_groups": [ "string" ], "updated_at": "string", "usage_limit": "integer" } ] ``` --- ## Create a Setup Key {{ tag: 'POST' , label: '/api/setup-keys' }} Creates a Setup Key #### Request-Body Parameters Setup Key name Setup key type, one-off for single time usage and reusable Expiration time in seconds Setup key revocation status Setup key groups to auto-assign to peers registered with this key A number of times this key can be used. The value of 0 indicates the unlimited usage. ```bash {{ title: 'cURL' }} curl -X POST https://api.netbird.io/api/setup-keys \ -H "Authorization: Token " \ -H 'Accept: application/json' \ -H 'Content-Type: application/json' \ --data-raw '{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }' ``` ```js const axios = require('axios'); let data = JSON.stringify({ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }); let config = { method: 'post', maxBodyLength: Infinity, url: '/api/setup-keys', headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'Authorization': 'Token ' }, data : data }; axios(config) .then((response) => { console.log(JSON.stringify(response.data)); }) .catch((error) => { console.log(error); }); ``` ```python import requests import json url = "https://api.netbird.io/api/setup-keys" payload = json.dumps({ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }) headers = { 'Content-Type': 'application/json', 'Accept': 'application/json', 'Authorization': 'Token ' } response = requests.request("POST", url, headers=headers, data=payload) print(response.text) ``` ```go package main import ( "fmt" "strings" "net/http" "io/ioutil" ) func main() { url := "https://api.netbird.io/api/setup-keys" method := "POST" payload := strings.NewReader(`{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }`) client := &http.Client { } req, err := http.NewRequest(method, url, payload) if err != nil { fmt.Println(err) return } req.Header.Add("Content-Type", "application/json") req.Header.Add("Accept", "application/json") req.Header.Add("Authorization", "Token ") res, err := client.Do(req) if err != nil { fmt.Println(err) return } defer res.Body.Close() body, err := ioutil.ReadAll(res.Body) if err != nil { fmt.Println(err) return } fmt.Println(string(body)) } ``` ```ruby require "uri" require "json" require "net/http" url = URI("https://api.netbird.io/api/setup-keys") https = Net::HTTP.new(url.host, url.port) https.use_ssl = true request = Net::HTTP::Post.new(url) request["Content-Type"] = "application/json" request["Accept"] = "application/json" request["Authorization"] = "Token " request.body = JSON.dump({ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }) response = https.request(request) puts response.read_body ``` ```java OkHttpClient client = new OkHttpClient().newBuilder() .build(); MediaType mediaType = MediaType.parse("application/json"); RequestBody body = RequestBody.create(mediaType, '{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }'); Request request = new Request.Builder() .url("https://api.netbird.io/api/setup-keys") .method("POST", body) .addHeader("Content-Type", "application/json") .addHeader("Accept", "application/json") .addHeader("Authorization: Token ") .build(); Response response = client.newCall(request).execute(); ``` ```php 'https://api.netbird.io/api/setup-keys', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }', CURLOPT_HTTPHEADER => array( 'Content-Type: application/json', 'Accept: application/json', 'Authorization: Token ' ), )); $response = curl_exec($curl); curl_close($curl); echo $response; ``` ```json {{ title: '200' }} { "id": "string", "key": "string", "name": "string", "expires": "string", "type": "string", "valid": "boolean", "revoked": "boolean", "used_times": "integer", "last_used": "string", "state": "string", "auto_groups": [ "string" ], "updated_at": "string", "usage_limit": "integer" } ``` --- ## Retrieve a Setup Key {{ tag: 'GET' , label: '/api/setup-keys/{keyId}' }} Get information about a Setup Key #### Path Parameters The unique identifier of a setup key ```bash {{ title: 'cURL' }} curl -X GET https://api.netbird.io/api/setup-keys/{keyId} \ -H "Authorization: Token " \ -H 'Accept: application/json' \ ``` ```js const axios = require('axios'); let config = { method: 'get', maxBodyLength: Infinity, url: '/api/setup-keys/{keyId}', headers: { 'Accept': 'application/json', 'Authorization': 'Token ' } }; axios(config) .then((response) => { console.log(JSON.stringify(response.data)); }) .catch((error) => { console.log(error); }); ``` ```python import requests import json url = "https://api.netbird.io/api/setup-keys/{keyId}" headers = { 'Accept': 'application/json', 'Authorization': 'Token ' } response = requests.request("GET", url, headers=headers) print(response.text) ``` ```go package main import ( "fmt" "strings" "net/http" "io/ioutil" ) func main() { url := "https://api.netbird.io/api/setup-keys/{keyId}" method := "GET" client := &http.Client { } req, err := http.NewRequest(method, url, nil) if err != nil { fmt.Println(err) return } req.Header.Add("Accept", "application/json") req.Header.Add("Authorization", "Token ") res, err := client.Do(req) if err != nil { fmt.Println(err) return } defer res.Body.Close() body, err := ioutil.ReadAll(res.Body) if err != nil { fmt.Println(err) return } fmt.Println(string(body)) } ``` ```ruby require "uri" require "json" require "net/http" url = URI("https://api.netbird.io/api/setup-keys/{keyId}") https = Net::HTTP.new(url.host, url.port) https.use_ssl = true request = Net::HTTP::Post.new(url) request["Accept"] = "application/json" request["Authorization"] = "Token " response = https.request(request) puts response.read_body ``` ```java OkHttpClient client = new OkHttpClient().newBuilder() .build(); MediaType mediaType = MediaType.parse("application/json"); RequestBody body = RequestBody.create(mediaType, ''); Request request = new Request.Builder() .url("https://api.netbird.io/api/setup-keys/{keyId}") .method("GET", body) .addHeader("Accept", "application/json") .addHeader("Authorization: Token ") .build(); Response response = client.newCall(request).execute(); ``` ```php 'https://api.netbird.io/api/setup-keys/{keyId}', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'GET', CURLOPT_POSTFIELDS =>'', CURLOPT_HTTPHEADER => array( 'Accept: application/json', 'Authorization: Token ' ), )); $response = curl_exec($curl); curl_close($curl); echo $response; ``` ```json {{ title: '200' }} { "id": "string", "key": "string", "name": "string", "expires": "string", "type": "string", "valid": "boolean", "revoked": "boolean", "used_times": "integer", "last_used": "string", "state": "string", "auto_groups": [ "string" ], "updated_at": "string", "usage_limit": "integer" } ``` --- ## Update a Setup Key {{ tag: 'PUT' , label: '/api/setup-keys/{keyId}' }} Update information about a Setup Key #### Path Parameters The unique identifier of a setup key #### Request-Body Parameters Setup Key name Setup key type, one-off for single time usage and reusable Expiration time in seconds Setup key revocation status Setup key groups to auto-assign to peers registered with this key A number of times this key can be used. The value of 0 indicates the unlimited usage. ```bash {{ title: 'cURL' }} curl -X PUT https://api.netbird.io/api/setup-keys/{keyId} \ -H "Authorization: Token " \ -H 'Accept: application/json' \ -H 'Content-Type: application/json' \ --data-raw '{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }' ``` ```js const axios = require('axios'); let data = JSON.stringify({ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }); let config = { method: 'put', maxBodyLength: Infinity, url: '/api/setup-keys/{keyId}', headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'Authorization': 'Token ' }, data : data }; axios(config) .then((response) => { console.log(JSON.stringify(response.data)); }) .catch((error) => { console.log(error); }); ``` ```python import requests import json url = "https://api.netbird.io/api/setup-keys/{keyId}" payload = json.dumps({ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }) headers = { 'Content-Type': 'application/json', 'Accept': 'application/json', 'Authorization': 'Token ' } response = requests.request("PUT", url, headers=headers, data=payload) print(response.text) ``` ```go package main import ( "fmt" "strings" "net/http" "io/ioutil" ) func main() { url := "https://api.netbird.io/api/setup-keys/{keyId}" method := "PUT" payload := strings.NewReader(`{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }`) client := &http.Client { } req, err := http.NewRequest(method, url, payload) if err != nil { fmt.Println(err) return } req.Header.Add("Content-Type", "application/json") req.Header.Add("Accept", "application/json") req.Header.Add("Authorization", "Token ") res, err := client.Do(req) if err != nil { fmt.Println(err) return } defer res.Body.Close() body, err := ioutil.ReadAll(res.Body) if err != nil { fmt.Println(err) return } fmt.Println(string(body)) } ``` ```ruby require "uri" require "json" require "net/http" url = URI("https://api.netbird.io/api/setup-keys/{keyId}") https = Net::HTTP.new(url.host, url.port) https.use_ssl = true request = Net::HTTP::Post.new(url) request["Content-Type"] = "application/json" request["Accept"] = "application/json" request["Authorization"] = "Token " request.body = JSON.dump({ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }) response = https.request(request) puts response.read_body ``` ```java OkHttpClient client = new OkHttpClient().newBuilder() .build(); MediaType mediaType = MediaType.parse("application/json"); RequestBody body = RequestBody.create(mediaType, '{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }'); Request request = new Request.Builder() .url("https://api.netbird.io/api/setup-keys/{keyId}") .method("PUT", body) .addHeader("Content-Type", "application/json") .addHeader("Accept", "application/json") .addHeader("Authorization: Token ") .build(); Response response = client.newCall(request).execute(); ``` ```php 'https://api.netbird.io/api/setup-keys/{keyId}', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'PUT', CURLOPT_POSTFIELDS =>'{ "name": "string", "type": "string", "expires_in": "integer", "revoked": "boolean", "auto_groups": [ "string" ], "usage_limit": "integer" }', CURLOPT_HTTPHEADER => array( 'Content-Type: application/json', 'Accept: application/json', 'Authorization: Token ' ), )); $response = curl_exec($curl); curl_close($curl); echo $response; ``` ```json {{ title: '200' }} { "id": "string", "key": "string", "name": "string", "expires": "string", "type": "string", "valid": "boolean", "revoked": "boolean", "used_times": "integer", "last_used": "string", "state": "string", "auto_groups": [ "string" ], "updated_at": "string", "usage_limit": "integer" } ``` ---