5
0
Fork 0
backend-heartbeat/README.md

1.4 KiB

backend-heartbeat

Beep backend records and makes available the last seen times of users.

Environment variables

Supply environment variables by either exporting them or editing .env.

ENV Description Default
LISTEN Host and port number to listen on :8080
REDIS Host and port of redis :6379

API

Subscribe User

GET /subscribe/:userid/client/:clientid

Subscribe to a user. Every time a user pings this service, the time will be sent to all subscribed users. Upon subscription, if it exists, the last cached time of the target user will be pushed immediately to the stream.

const es = new EventSource(`${host}/subscribe/${user}/client/${device}`);
es.onmessage = (e) => {
  const timestamp = e.data;
  // Do whatever with the timestamp
};

URL Params

Name Type Description Required
userid String Target user's ID.
clientid String Target user's device's ID.

Success Response (200 OK)

An EventSource stream.


Ping Server

POST /ping/:userid/client/:clientid

Ping the server.

URL Params

Name Type Description Required
userid String User's ID.
clientid String User's device's ID.

Success Response (200 OK)

Empty body.