The Health service is designed to allow you to both validate and monitor that your Appwrite instance and all of its internal components are up and responsive.
https://<REGION>.cloud.appwrite.io/v1
Get antivirus
Check the Appwrite Antivirus server is up and connection is successful.
- Response- 200 application/json 
 
GET /health/anti-virus
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthAntivirus result = await health.GetAntivirus();
Get cache
Check the Appwrite in-memory cache servers are up and connection is successful.
- Response- 200 application/json 
 
GET /health/cache
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthStatus result = await health.GetCache();
Get DB
Check the Appwrite database servers are up and connection is successful.
- Response- 200 application/json 
 
GET /health/db
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthStatus result = await health.GetDB();
GET /health
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthStatus result = await health.Get();
Get pubsub
Check the Appwrite pub-sub servers are up and connection is successful.
- Response- 200 application/json 
 
GET /health/pubsub
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthStatus result = await health.GetPubSub();
Get the SSL certificate for a domain
Get the SSL certificate for a domain
- Request- domain string - string 
 
- Response- 200 application/json 
 
GET /health/certificate
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthCertificate result = await health.GetCertificate(
    domain: "" // optional
);
Get time
Check the Appwrite server time is synced with Google remote NTP server. We use this technology to smoothly handle leap seconds with no disruptive events. The Network Time Protocol (NTP) is used by hundreds of millions of computers and devices to synchronize their clocks over the Internet. If your computer sets its own clock, it likely uses NTP.
- Response- 200 application/json 
 
GET /health/time
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthTime result = await health.GetTime();
Get builds queue
Get the number of builds that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/builds
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueBuilds(
    threshold: 0 // optional
);
Get certificates queue
Get the number of certificates that are waiting to be issued against Letsencrypt in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/certificates
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueCertificates(
    threshold: 0 // optional
);
Get databases queue
Get the number of database changes that are waiting to be processed in the Appwrite internal queue server.
- Request- name string - Queue name for which to check the queue size 
- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/databases
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueDatabases(
    name: "<NAME>", // optional
    threshold: 0 // optional
);
Get deletes queue
Get the number of background destructive changes that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/deletes
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueDeletes(
    threshold: 0 // optional
);
Get functions queue
Get the number of function executions that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/functions
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueFunctions(
    threshold: 0 // optional
);
Get logs queue
Get the number of logs that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/logs
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueLogs(
    threshold: 0 // optional
);
Get mails queue
Get the number of mails that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/mails
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueMails(
    threshold: 0 // optional
);
Get messaging queue
Get the number of messages that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/messaging
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueMessaging(
    threshold: 0 // optional
);
Get migrations queue
Get the number of migrations that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/migrations
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueMigrations(
    threshold: 0 // optional
);
Get number of failed queue jobs
Returns the amount of failed jobs in a given queue.
- Request- name string required- The name of the queue 
- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/failed/{name}
using Appwrite;
using Appwrite.Enums;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetFailedJobs(
    name: .V1Database,
    threshold: 0 // optional
);
Get stats resources queue
Get the number of metrics that are waiting to be processed in the Appwrite stats resources queue.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/stats-resources
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueStatsResources(
    threshold: 0 // optional
);
Get stats usage queue
Get the number of metrics that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/stats-usage
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueUsage(
    threshold: 0 // optional
);
Get webhooks queue
Get the number of webhooks that are waiting to be processed in the Appwrite internal queue server.
- Request- threshold integer - Queue size threshold. When hit (equal or higher), endpoint returns server error. Default value is 5000. 
 
- Response- 200 application/json 
 
GET /health/queue/webhooks
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthQueue result = await health.GetQueueWebhooks(
    threshold: 0 // optional
);
Get local storage
Check the Appwrite local storage device is up and connection is successful.
- Response- 200 application/json 
 
GET /health/storage/local
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthStatus result = await health.GetStorageLocal();
Get storage
Check the Appwrite storage device is up and connection is successful.
- Response- 200 application/json 
 
GET /health/storage
using Appwrite;
using Appwrite.Models;
using Appwrite.Services;
Client client = new Client()
    .SetEndPoint("https://<REGION>.cloud.appwrite.io/v1") // Your API Endpoint
    .SetProject("<YOUR_PROJECT_ID>") // Your project ID
    .SetKey("<YOUR_API_KEY>"); // Your secret API key
Health health = new Health(client);
HealthStatus result = await health.GetStorage();