Kounter is a simple counter service that can be used in various ways.
Use cases include a profile views counter, repository visits counter, or anything you want to count.
For development, you must set the DETA_PROJECT_KEY
environment variable to your Deta project key.
This project uses Bun for development.
bun dev
Kounter is built using Fastify.
It has a straightforward API with the following few endpoints.
Note
You can also check the Swagger API documentation for more details.
Base URL: https://kounter.kerolloz.dev
Redirects to this repository.
- Increments the counter by 1 if
:key
exits; creates a new counter with count initialized to 1 otherwise. - Returns a shields.io badge (SVG image) for your counter.
key
- The key of the counter to increment.
silent
- Set totrue
to disable incrementing the counter. Defaults tofalse
.style
- Set the style of the badge. Can be one offlat
,flat-square
,for-the-badge
, orplastic
. Defaults toflat
.label
- Set the left-hand-side text. Defaults to:key
.color
- Set the background of the right part (hex, rgb, rgba, hsl, hsla and css named colors supported). Defaults tobrightgreen
.labelColor
- Set the background of the left part (hex, rgb, rgba, hsl, hsla and css named colors supported). Defaults togrey
.cntPrefix
- Set prefix to display before the counter value. Defaults to""
empty string.cntSuffix
- Set suffix to display after the counter value. Defaults to""
empty string.
data:image/s3,"s3://crabby-images/26465/264652a10b2effe756a58ad7c9e2e1bed5aca3db" alt="badge"
data:image/s3,"s3://crabby-images/95f77/95f77b161508a00b08f40913b7e319e6b117a822" alt="badge"
data:image/s3,"s3://crabby-images/a58e6/a58e60704140a9435d328516d3ffe64db6288cba" alt="badge"
data:image/s3,"s3://crabby-images/f5a66/f5a66c168936d41240250fe90b8ff0c84629dba5" alt="badge"
- Returns the current count for
:key
without incrementing it. - Returns
{ key: ":key", count: 0 }
if the counter:key
does not exist.
key
- The key of the counter to get count value for.
$ curl -X GET https://kounter.kerolloz.dev/count/xyz
{
"count": 1,
"key": "xyz"
}