Create link
Create a new short link. The link is assigned a unique slug and automatically tracks click analytics including referrers, geography, and device information.
curl -X POST "https://api.mythic-analytics.com/api/v1/links" \
-H "Content-Type: application/json" \
-H "Authorization: Bearer YOUR_API_TOKEN" \
-d '{
"destination_url": "https://acme-retail.com/summer-sale",
"slug": "summer-sale",
"title": "Summer Sale Campaign",
"client_id": "acme-retail",
"tags": [
"campaign",
"summer-2024"
],
"password": "example_string",
"expires_at": "2024-12-25T10:00:00Z",
"metadata": {}
}'
import requests
import json
url = "https://api.mythic-analytics.com/api/v1/links"
headers = {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN"
}
data = {
"destination_url": "https://acme-retail.com/summer-sale",
"slug": "summer-sale",
"title": "Summer Sale Campaign",
"client_id": "acme-retail",
"tags": [
"campaign",
"summer-2024"
],
"password": "example_string",
"expires_at": "2024-12-25T10:00:00Z",
"metadata": {}
}
response = requests.post(url, headers=headers, json=data)
print(response.json())
const response = await fetch("https://api.mythic-analytics.com/api/v1/links", {
method: "POST",
headers: {
"Content-Type": "application/json",
"Authorization": "Bearer YOUR_API_TOKEN"
},
body: JSON.stringify({
"destination_url": "https://acme-retail.com/summer-sale",
"slug": "summer-sale",
"title": "Summer Sale Campaign",
"client_id": "acme-retail",
"tags": [
"campaign",
"summer-2024"
],
"password": "example_string",
"expires_at": "2024-12-25T10:00:00Z",
"metadata": {}
})
});
const data = await response.json();
console.log(data);
package main
import (
"fmt"
"net/http"
"bytes"
"encoding/json"
)
func main() {
data := []byte(`{
"destination_url": "https://acme-retail.com/summer-sale",
"slug": "summer-sale",
"title": "Summer Sale Campaign",
"client_id": "acme-retail",
"tags": [
"campaign",
"summer-2024"
],
"password": "example_string",
"expires_at": "2024-12-25T10:00:00Z",
"metadata": {}
}`)
req, err := http.NewRequest("POST", "https://api.mythic-analytics.com/api/v1/links", 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/links')
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'
request.body = '{
"destination_url": "https://acme-retail.com/summer-sale",
"slug": "summer-sale",
"title": "Summer Sale Campaign",
"client_id": "acme-retail",
"tags": [
"campaign",
"summer-2024"
],
"password": "example_string",
"expires_at": "2024-12-25T10:00:00Z",
"metadata": {}
}'
response = http.request(request)
puts response.body
{
"success": true,
"data": {
"id": "lnk_9xP3qLmN",
"destination_url": "https://acme-retail.com/summer-sale",
"short_url": "https://go.mythic-analytics.com/summer-sale",
"slug": "summer-sale",
"title": "Summer Sale Campaign",
"client_id": "acme-retail",
"clicks": 1247,
"tags": [
"example_string"
],
"has_password": false,
"expires_at": "2024-12-25T10:00:00Z",
"metadata": {},
"created_at": "2024-06-01T12:00:00.000Z",
"updated_at": "2024-06-15T08:30:00.000Z"
}
}
{
"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": "Conflict",
"message": "The request conflicts with the current state of the resource",
"code": 409,
"details": "Resource already exists"
}
/links
Admin API key as bearer token. Format: Bearer YOUR_ADMIN_KEY
Bearer YOUR_ADMIN_KEYThe media type of the request body
Target URL the short link redirects to.
Custom slug. Auto-generated if omitted.
Human-readable title.
Associate the link with a client tenant.
Optional password protection for the link.
Optional expiration date.
Arbitrary JSON metadata.
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
Body
Target URL the short link redirects to.
Custom slug. Auto-generated if omitted.
Human-readable title.
Associate the link with a client tenant.
Optional password protection for the link.
Optional expiration date.
Arbitrary JSON metadata.
Responses
Last updated today