|
|
<!DOCTYPE html> |
|
|
<html lang="en"> |
|
|
<head> |
|
|
<meta charset="UTF-8"> |
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
|
|
<title>API Endpoints | CookieSync</title> |
|
|
<link rel="stylesheet" href="style.css"> |
|
|
<script src="https://cdn.tailwindcss.com"></script> |
|
|
<script src="https://cdn.jsdelivr.net/npm/feather-icons/dist/feather.min.js"></script> |
|
|
<script src="components/navbar.js"></script> |
|
|
<script src="components/sidebar.js"></script> |
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/highlight.min.js"></script> |
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/styles/github-dark.min.css"> |
|
|
</head> |
|
|
<body class="bg-gray-100 dark:bg-gray-900 text-gray-900 dark:text-gray-100"> |
|
|
<custom-navbar></custom-navbar> |
|
|
|
|
|
<div class="flex"> |
|
|
<custom-sidebar></custom-sidebar> |
|
|
|
|
|
<main class="flex-1 p-6 ml-64"> |
|
|
<h1 class="text-2xl font-bold mb-6 flex items-center"> |
|
|
<i data-feather="terminal" class="mr-2"></i> API Endpoints |
|
|
</h1> |
|
|
|
|
|
<div class="bg-white dark:bg-gray-800 rounded-lg shadow p-6 mb-6"> |
|
|
<h2 class="text-xl font-bold mb-4">API Documentation</h2> |
|
|
<p class="mb-6 text-gray-600 dark:text-gray-400">Interact with CookieSync programmatically using our REST API. All endpoints require authentication via API key.</p> |
|
|
|
|
|
<div class="mb-8"> |
|
|
<h3 class="font-medium mb-2 flex items-center"> |
|
|
<span class="bg-blue-600 text-white text-xs font-medium px-2 py-1 rounded mr-2">GET</span> |
|
|
/api/v1/sessions |
|
|
</h3> |
|
|
<p class="text-sm text-gray-600 dark:text-gray-400 mb-3">Retrieve a list of active sessions.</p> |
|
|
|
|
|
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg mb-3"> |
|
|
<pre><code class="language-bash">curl -X GET \ |
|
|
https://api.cookiesync.ai/v1/sessions \ |
|
|
-H 'Authorization: Bearer YOUR_API_KEY'</code></pre> |
|
|
</div> |
|
|
|
|
|
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg"> |
|
|
<pre><code class="language-json">{ |
|
|
"data": [ |
|
|
{ |
|
|
"id": "sess_abc123", |
|
|
"status": "active", |
|
|
"created_at": "2023-11-15T14:32:45Z", |
|
|
"last_used": "2023-11-15T15:12:33Z", |
|
|
"metadata": { |
|
|
"ip": "192.168.1.45", |
|
|
"user_agent": "Mozilla/5.0" |
|
|
} |
|
|
} |
|
|
] |
|
|
}</code></pre> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div class="mb-8"> |
|
|
<h3 class="font-medium mb-2 flex items-center"> |
|
|
<span class="bg-green-600 text-white text-xs font-medium px-2 py-1 rounded mr-2">POST</span> |
|
|
/api/v1/sessions |
|
|
</h3> |
|
|
<p class="text-sm text-gray-600 dark:text-gray-400 mb-3">Create a new session.</p> |
|
|
|
|
|
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg mb-3"> |
|
|
<pre><code class="language-bash">curl -X POST \ |
|
|
https://api.cookiesync.ai/v1/sessions \ |
|
|
-H 'Authorization: Bearer YOUR_API_KEY' \ |
|
|
-H 'Content-Type: application/json' \ |
|
|
-d '{ |
|
|
"cookies": "cookie1=value1; cookie2=value2", |
|
|
"expires_in": 3600 |
|
|
}'</code></pre> |
|
|
</div> |
|
|
|
|
|
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg"> |
|
|
<pre><code class="language-json">{ |
|
|
"data": { |
|
|
"id": "sess_def456", |
|
|
"status": "active", |
|
|
"created_at": "2023-11-15T16:45:22Z", |
|
|
"expires_at": "2023-11-15T17:45:22Z", |
|
|
"metadata": { |
|
|
"ip": "192.168.1.45" |
|
|
} |
|
|
} |
|
|
}</code></pre> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div class="mb-8"> |
|
|
<h3 class="font-medium mb-2 flex items-center"> |
|
|
<span class="bg-red-600 text-white text-xs font-medium px-2 py-1 rounded mr-2">DELETE</span> |
|
|
/api/v1/sessions/{id} |
|
|
</h3> |
|
|
<p class="text-sm text-gray-600 dark:text-gray-400 mb-3">Terminate a session.</p> |
|
|
|
|
|
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg mb-3"> |
|
|
<pre><code class="language-bash">curl -X DELETE \ |
|
|
https://api.cookiesync.ai/v1/sessions/sess_abc123 \ |
|
|
-H 'Authorization: Bearer YOUR_API_KEY'</code></pre> |
|
|
</div> |
|
|
|
|
|
<div class="bg-gray-100 dark:bg-gray-700 p-4 rounded-lg"> |
|
|
<pre><code class="language-json">{ |
|
|
"data": { |
|
|
"id": "sess_abc123", |
|
|
"status": "terminated", |
|
|
"terminated_at": "2023-11-15T16:48:15Z" |
|
|
} |
|
|
}</code></pre> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div class="bg-white dark:bg-gray-800 rounded-lg shadow p-6"> |
|
|
<h2 class="text-xl font-bold mb-4">API Key Management</h2> |
|
|
|
|
|
<div class="space-y-4 mb-6"> |
|
|
<div> |
|
|
<label class="block text-sm font-medium mb-1">Your API Key</label> |
|
|
<div class="flex"> |
|
|
<input type="password" class="w-full p-2 border rounded-l dark:bg-gray-700 dark:border-gray-600" value="sk_test_1234567890abcdef" readonly> |
|
|
<button class="bg-gray-200 hover:bg-gray-300 dark:bg-gray-700 dark:hover:bg-gray-600 px-3 rounded-r"> |
|
|
<i data-feather="eye" class="w-4 h-4"></i> |
|
|
</button> |
|
|
<button class="bg-gray-200 hover:bg-gray-300 dark:bg-gray-700 dark:hover:bg-gray-600 px-3 rounded ml-2"> |
|
|
<i data-feather="copy" class="w-4 h-4"></i> |
|
|
</button> |
|
|
</div> |
|
|
<p class="text-xs text-gray-500 dark:text-gray-400 mt-1">Keep this key secret. It provides full access to your account.</p> |
|
|
</div> |
|
|
|
|
|
<div> |
|
|
<label class="block text-sm font-medium mb-1">Regenerate API Key</label> |
|
|
<p class="text-sm text-gray-600 dark:text-gray-400 mb-2">Generating a new key will immediately invalidate the current one.</p> |
|
|
<button class="bg-red-600 hover:bg-red-700 text-white py-2 px-4 rounded text-sm"> |
|
|
Generate New Key |
|
|
</button> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div class="border-t dark:border-gray-700 pt-6"> |
|
|
<h3 class="font-medium mb-2">API Usage</h3> |
|
|
<div class="grid grid-cols-1 md:grid-cols-3 gap-4"> |
|
|
<div class="bg-blue-50 dark:bg-blue-900/20 p-4 rounded-lg"> |
|
|
<div class="text-sm text-blue-600 dark:text-blue-400 mb-1">Requests Today</div> |
|
|
<div class="text-2xl font-bold">142</div> |
|
|
<div class="text-xs text-blue-600 dark:text-blue-400 mt-1">+12% from yesterday</div> |
|
|
</div> |
|
|
<div class="bg-green-50 dark:bg-green-900/20 p-4 rounded-lg"> |
|
|
<div class="text-sm text-green-600 dark:text-green-400 mb-1">Success Rate</div> |
|
|
<div class="text-2xl font-bold">98.7%</div> |
|
|
<div class="text-xs text-green-600 dark:text-green-400 mt-1">99.1% last week</div> |
|
|
</div> |
|
|
<div class="bg-purple-50 dark:bg-purple-900/20 p-4 rounded-lg"> |
|
|
<div class="text-sm text-purple-600 dark:text-purple-400 mb-1">Rate Limit</div> |
|
|
<div class="text-2xl font-bold">100/min</div> |
|
|
<div class="text-xs text-purple-600 dark:text-purple-400 mt-1">5 requests used</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</main> |
|
|
</div> |
|
|
|
|
|
<script src="script.js"></script> |
|
|
<script> |
|
|
feather.replace(); |
|
|
hljs.highlightAll(); |
|
|
</script> |
|
|
</body> |
|
|
</html> |