This server moves information from a Gravity Forms form hosted on Wordpress and creates/updates session on an event in the Sched platform.
It also provides APIs for use in the administration web UI.
The Sched components will automatically throttle API calls to meet limits defined in their API documentation (30 calls/minute).
Uses Node 20 LTS, Typescript, superagent for HTTP/REST, tsyringe for dependency injection, pm2 for daemon/process management
npm run start
- runs in daemon mode and polls the GF for changes every 10 minutes
npm run pm2-start
- runs with pm2 process management (for deployment)
npm run pm2-stop
- kills pm2-started process
Several environment variables must be set, or even better a .env
file should be created:
GF_URI
- set to your base URL for the server where your Gravity Forms is hosted, must be HTTPS ( e.g. https://www.madisonbikes.org/)GF_FORM_ID
- set to the form ID of the formGF_CONSUMER_API_KEY
- see Gravity Forms documentation, this key is used with basic authentication against the serverGF_CONSUMER_SECRET
- see Gravity Forms documentation, this secret is used with basic authentication against the serverSCHED_API_KEY
(set to your Sched API key)SCHED_URI
(set to your base Sched endpoint, e.g. https://madisonbikeweek2022.sched.com)ENABLE_CORS
(set to true if bikeweek-client and bikeweek-server are not being served from same port and host, normally only development)JSONWEBTOKEN_SECRET
- Set this to a long string of random digits or words unique to the server. Used to secure JWT tokens.PORT
- change the port on which the server runs. Default is 3001.STATIC_ROOT_DIR
- set to the location of the bikeweek-server build directory. Used in production to serve both APIs and React client from same host/port.
This repository enforces Conventional Commits as of July 2022.