1️⃣ Create a project
Go to your projects page and click the button + Create Project
Give it a unique short name (lowercase letters, digits, and the characters '.', '_', and '-')
2️⃣ Create a project token
After creating your first project, go to Settings > Tokens
Give the token a unique short name then click on Create
You can now copy the token by clicking the copy button next to the token.
3️⃣ Setup Discord Webhook
On Discord, create a new server or, on an existing server, click on Edit Channel
In the channel settings, click on Integrations
then Create Webhook
A new webhook will be created. Give it a name then click on Copy Webhook URL
On Minilog, go to your project, Settings > Alerts
, then paste the webhook in the Discord text field, then click Save
🎉 Send your first event
To send an event to Minilog, make an authenticated HTTP POST request to the Event API .
The HTTP request can fail (no internet, quota exceeded), make sure to handle exceptions according to your programming language.
HTTP requests can take some time to complete (a few hundred milliseconds), make sure to not block your main process while sending logs.
Javascript Python C# PHP cURL PowerShell
Copy await fetch("https://api.minilog.dev/v1/events/<project-name>", {
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: "Bearer <project-token>",
},
body: JSON.stringify({
channel: "cron-jobs",
title: "Cron Job Success",
description: "The daily backup job completed successfully",
icon: "⏰",
tags:{
job_name: "daily_backup",
duration: "15 minutes",
status: "success",
next_run: "2024-09-05 02:00 UTC"
}
}),
});
Copy import requests
import json
url = "https://api.minilog.dev/v1/events/<project-name>"
headers = {
"Content-Type": "application/json",
"Authorization": "Bearer <project-token>",
}
data = {
channel: "cron-jobs",
title: "Cron Job Success",
description: "The daily backup job completed successfully",
icon: "⏰",
tags:{
job_name: "daily_backup",
duration: "15 minutes",
status: "success",
next_run: "2024-09-05 02:00 UTC"
}
}
response = requests.post(url, headers=headers, data=json.dumps(data))
print(response.status_code)
Copy using System;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;
class Program
{
static async Task Main()
{
var url = "https://api.minilog.dev/v1/events/<project-name>";
var token = "<project-token>";
var json = "{\"channel\": \"cron-jobs\",\"title\": \"Cron Job Success\",\"description\": \"The daily backup job completed successfully\",\"icon\":\"⏰\", \"tags\": {\"job_name\": \"daily_backup\"}}";
using (var client = new HttpClient())
{
client.DefaultRequestHeaders.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", token);
var content = new StringContent(json, Encoding.UTF8, "application/json");
var response = await client.PostAsync(url, content);
Console.WriteLine(response.StatusCode);
}
}
}
Copy <?php
$url = 'https://api.minilog.dev/v1/events/<project-name>';
$token = '<project-token>';
$data = array(
'channel' => 'cron-jobs',
'title' => 'Cron Job Success',
'description' => 'The daily backup job completed successfully',
'icon' => '⏰'
'tags' => array('job_name' => 'daily_backup')
);
$options = array(
'http' => array(
'header' => "Content-Type: application/json\r\n" .
"Authorization: Bearer " . $token . "\r\n",
'method' => 'POST',
'content' => json_encode($data),
),
);
$context = stream_context_create($options);
$response = file_get_contents($url, false, $context);
if ($response === false) {
echo "Error fetching data";
} else {
echo $response;
}
?>
Copy curl -X POST https://api.minilog.dev/v1/events/<project-name> \
-H "Content-Type: application/json" \
-H "Authorization: Bearer <project-token>" \
-d '{
"channel": "cron-jobs",
"title": "Cron Job Success",
"description":"The daily backup job completed successfully.",
"icon": "⏰",
"notify": true,
"tags":{
"job_name": "daily_backup",
"duration": "15 minutes",
"status": "success",
"next_run": "2024-09-05 02:00 UTC"
}
}'
Copy $uri = 'https://api.minilog.dev/v1/events/<project-name>'
$headers = @{
'Content-Type' = 'application/json'
'Authorization' = 'Bearer <project-token>'
}
$body = @{
channel = 'cron-jobs'
title = 'Cron Job Success'
description = 'The daily backup job completed successfully',
icon = '⏰',
tags = @{
hostname = 'vm-1'
}
}
Invoke-RestMethod -Uri $uri -Method Post -Headers $headers -Body ($body | ConvertTo-Json)