Hi! We're really excited that you're interested in contributing! Before submitting your contribution, please read through the following guide.
- Bug fixes and changes discussed in the existing issues are always welcome.
- For new ideas, please open an issue to discuss them before sending a PR.
- Make sure your PR passes
npm test
and has appropriate commit messages.
In order to run the Globalping API locally you will need Node.js 20 and Redis with RedisJSON module and MariaDB. All of them are included in docker-compose.dev.yml file. You will also need to run a development instance of the Globalping Probe at the same time when testing.
The API uses 3000 port by default. This can be overridden by PORT
environment variable.
You can run the project by following these steps:
- Clone this repository.
- Enable host networking in Docker Desktop if you haven't already.
docker compose -f docker-compose.dev.yml up -d
- Run Redis and MariaDBnpm install && npm run download:files
- Run
npm run start:dev
Once the API is live, you can spin up a probe instance by running as described at https://github.com/jsdelivr/globalping-probe/blob/master/CONTRIBUTING.md.
PORT=3000
environment variable can start the API on another port (default is 3000)FAKE_PROBE_IP=1
environment variable can be used to make debug easier. When defined, every Probe that connects to the API will get an IP address from the list of predefined "real" addresses.
A single command to run everything: npm test
To run a specific linter or a test suite, please see the scripts section of package.json.
Most IDEs have plugins integrating the used linter (eslint), including support for automated fixes on save.
ELASTIC_APM_SERVER_URL={value}
used in production to send APM metrics to elasticELASTIC_APM_SECRET_TOKEN={value}
used in production to send APM metrics to elasticELASTIC_SEARCH_URL={value}
used in production to send logs to elasticFAKE_PROBE_IP=1
used in development to use a random fake ip assigned by the APIADMIN_KEY={value}
used to access additional information over the APISYSTEM_API_KEY={value}
used for integration with the dashboardSERVER_SESSION_COOKIE_SECRET={value}
used to read the shared session cookieDB_CONNECTION_HOST
,DB_CONNECTION_USER
,DB_CONNECTION_PASSWORD
, andDB_CONNECTION_DATABASE
database connection detailsREDIS_STANDALONE_PERSISTENT_URL
,REDIS_STANDALONE_NON_PERSISTENT_URL
,REDIS_CLUSTER_MEASUREMENTS_NODES_0
,REDIS_CLUSTER_MEASUREMENTS_NODES_1
,REDIS_CLUSTER_MEASUREMENTS_NODES_2
, andREDIS_SHARED_OPTIONS_PASSWORD
- redis connection details