Api Subtitle
Api Intro
https://www.estacaido.com/api/v1/
Api Rate Limits Desc
Api Auth Desc
/api/v1/auth/token/
curl -X POST https://www.estacaido.com/api/v1/auth/token/ \
-H "Content-Type: application/json" \
-d '{"username": "your@email.com", "password": "yourpassword"}'
{
"token": "your-api-token-here"
}
Authorization: Token your-api-token-here
Api Monitors Desc
/api/v1/monitors/
[
{
"id": 1,
"name": "Production API",
"company": {
"id": 1,
"website": "api.example.com"
},
"check_type": "http",
"check_interval": 5,
"is_active": true,
"is_paused": false,
"last_check_at": "2024-01-15T10:30:00Z",
"created_at": "2024-01-01T00:00:00Z"
}
]
/api/v1/monitors/
name |
Required | Api Param Name |
domain |
Required | Api Param Domain |
check_interval |
Optional | Api Param Interval |
check_type |
Optional | Api Param Check Type |
/api/v1/monitors/{id}/
/api/v1/monitors/{id}/
/api/v1/monitors/{id}/
/api/v1/monitors/{id}/pause/
/api/v1/monitors/{id}/resume/
/api/v1/monitors/{id}/statistics/
days |
Optional | Api Param Days |
Api Incidents Desc
/api/v1/incidents/
status |
Optional | Api Param Status |
monitor |
Optional | Api Param Monitor Id |
/api/v1/incidents/{id}/
Api Alerts Desc
/api/v1/alerts/
/api/v1/alerts/
monitor |
Required | Api Param Monitor Id |
alert_type |
Required | Api Param Alert Type |
recipients |
Required | Api Param Recipients |
alert_on_down |
Optional | Api Param Alert Down |
alert_on_recovery |
Optional | Api Param Alert Recovery |
/api/v1/alerts/{id}/
/api/v1/alerts/{id}/
Api Status Pages Desc
/api/v1/status-pages/
/api/v1/status-pages/
title |
Required | Api Param Title |
slug |
Required | Api Param Slug |
description |
Optional | Api Param Description |
is_public |
Optional | Api Param Public |
Api Teams Desc
/api/v1/teams/
/api/v1/teams/
/api/v1/teams/{id}/
import requests
API_TOKEN = 'your-api-token'
BASE_URL = 'https://www.estacaido.com/api/v1'
headers = {
'Authorization': f'Token {API_TOKEN}',
'Content-Type': 'application/json'
}
# List all monitors
response = requests.get(f'{BASE_URL}/monitors/', headers=headers)
monitors = response.json()
print(monitors)
# Create a new monitor
new_monitor = {
'name': 'My Website',
'domain': 'example.com',
'check_interval': 5
}
response = requests.post(f'{BASE_URL}/monitors/', json=new_monitor, headers=headers)
print(response.json())
const API_TOKEN = 'your-api-token';
const BASE_URL = 'https://www.estacaido.com/api/v1';
const headers = {
'Authorization': `Token ${API_TOKEN}`,
'Content-Type': 'application/json'
};
// List all monitors
fetch(`${BASE_URL}/monitors/`, { headers })
.then(res => res.json())
.then(monitors => console.log(monitors));
// Create a new monitor
fetch(`${BASE_URL}/monitors/`, {
method: 'POST',
headers,
body: JSON.stringify({
name: 'My Website',
domain: 'example.com',
check_interval: 5
})
})
.then(res => res.json())
.then(data => console.log(data));
# List all monitors
curl -X GET https://www.estacaido.com/api/v1/monitors/ \
-H "Authorization: Token your-api-token"
# Create a new monitor
curl -X POST https://www.estacaido.com/api/v1/monitors/ \
-H "Authorization: Token your-api-token" \
-H "Content-Type: application/json" \
-d '{"name": "My Website", "domain": "example.com", "check_interval": 5}'