Replace snippets
Replace all custom code snippets for a client. Snippets are arbitrary HTML or JavaScript injected via remote configuration. After updating, the API rebuilds the client's remote configuration in KV.
curl -X PUT "https://api.mythic-analytics.com/api/v1/clients/example_string/snippets" \
-H "Content-Type: application/json" \
-H "Authorization: Bearer YOUR_API_TOKEN" \
-d '{
"snippets": [
{
"code": "example_string",
"description": "example_string",
"enabled": true,
"trigger_rules": {}
}
]
}'
import requests
import json
url = "https://api.mythic-analytics.com/api/v1/clients/example_string/snippets"
headers = {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN"
}
data = {
"snippets": [
{
"code": "example_string",
"description": "example_string",
"enabled": true,
"trigger_rules": {}
}
]
}
response = requests.put(url, headers=headers, json=data)
print(response.json())
const response = await fetch("https://api.mythic-analytics.com/api/v1/clients/example_string/snippets", {
method: "PUT",
headers: {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN"
},
body: JSON.stringify({
"snippets": [
{
"code": "example_string",
"description": "example_string",
"enabled": true,
"trigger_rules": {}
}
]
})
});
const data = await response.json();
console.log(data);
package main
import (
"fmt"
"net/http"
"bytes"
"encoding/json"
)
func main() {
data := []byte(`{
"snippets": [
{
"code": "example_string",
"description": "example_string",
"enabled": true,
"trigger_rules": {}
}
]
}`)
req, err := http.NewRequest("PUT", "https://api.mythic-analytics.com/api/v1/clients/example_string/snippets", bytes.NewBuffer(data))
if err != nil {
panic(err)
}
req.Header.Set("Content-Type", "application/json")
req.Header.Set("Authorization", "Bearer YOUR_API_TOKEN")
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.mythic-analytics.com/api/v1/clients/example_string/snippets')
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = true
request = Net::HTTP::Put.new(uri)
request['Content-Type'] = 'application/json'
request['Authorization'] = 'Bearer YOUR_API_TOKEN'
request.body = '{
"snippets": [
{
"code": "example_string",
"description": "example_string",
"enabled": true,
"trigger_rules": {}
}
]
}'
response = http.request(request)
puts response.body
{
"success": true,
"data": [
{
"id": "9xP3qLmN-58cc-4372-a567-0e02b2c3d479",
"code": "<script src="https://widgets.mythic-analytics.com/checkout.js"></script>",
"description": "Checkout widget",
"enabled": true,
"trigger_rules": {}
}
]
}
{
"error": "Bad Request",
"message": "The request contains invalid parameters or malformed data",
"code": 400,
"details": [
{
"field": "email",
"message": "Invalid email format"
}
]
}
{
"error": "Unauthorized",
"message": "Authentication required. Please provide a valid API token",
"code": 401
}
{
"error": "Not Found",
"message": "The requested resource was not found",
"code": 404
}
/clients/{id}/snippetsAdmin API key as bearer token. Format: Bearer YOUR_ADMIN_KEY
Bearer YOUR_ADMIN_KEYAlternative to the Authorization header for server-to-server scenarios.
Client identifier.
The media type of the request body
Array of snippet objects. Replaces all existing snippets.
Request Preview
Response
Response will appear here after sending the request
Authentication
Bearer token. Admin API key as bearer token. Format: Bearer YOUR_ADMIN_KEY
API Key for authentication. Alternative to the Authorization header for server-to-server scenarios.
Path Parameters
Client identifier.
Body
Array of snippet objects. Replaces all existing snippets.
Raw HTML or JavaScript code to inject.
Human-readable description.
Whether the snippet is active.
Conditional rules controlling when the snippet loads.
Responses
Auto-generated snippet ID.
Raw HTML or JavaScript code to inject.
Last updated Feb 26, 2026
Built with Documentation.AI