"OrienteerFeed" is designed to be a dynamic and interactive web API platform which is specifically made for the orienteering community. Delivering real-time updates, live tracking, and a continuous stream of information about orienteering events is its key service.
⭐ Star us on GitHub — it motivates us a lot!
This application is like a digital hub for all things related to orienteering events. It serves as a one-stop platform where you can get details about various events, the classes offered at these events, and the competitors participating in them. It provides these services through a web server and is capable of communicating using both RESTful APIs and GraphQL, which are two ways of fetching data from a server.
- Web Server: Built on Node.js and Express, this server acts as the central point that handles all requests from users' browsers or apps. It processes these requests and sends back the required information.
- RESTful API: This is a set of URLs (like links you click on the web) that you can access to get data about events, competitors, etc. For example, you might have a URL to get a list of all events and another to get detailed information about a specific event. You can access the API documentation by visiting
[server]/api-docs
in your web browser. This documentation is presented in the Swagger format, which provides a clear and interactive way of understanding the available API endpoints, their required parameters, and the responses they return. This tool also allows you to directly test API requests from within the documentation interface to see real-time responses from the server. - GraphQL API: Unlike the RESTful API where each type of data might have its URL, GraphQL allows you to send queries to a single endpoint to fetch exactly the data you need. For example, you could ask for the names of all competitors in a specific class without getting any other unnecessary data. Explore and interact with our GraphQL API using the Apollo Sandbox by navigating to
[server]/graphql
in your web browser. The Apollo Sandbox provides an intuitive, interactive environment where you can construct and test your GraphQL queries and mutations directly against our live data. - Persistence Storage: This is where all the data about events, classes, competitors, etc., is stored. Each time you make a query, the server retrieves data from this storage. It is set up using the MariaDB database.
- Our application secures sensitive operations, such as adding or modifying event details, through a robust user authentication system. Users are required to log in to gain access to these features. Authentication is managed using JSON Web Tokens (JWT), a secure method that helps ensure that only authorized users can perform certain actions.
- When a user logs in, they receive a JWT that encapsulates their user credentials and permissions.
- This token must be included as a Bearer token in the headers of HTTP requests made to the API for operations that modify data.
- The server validates this token to ensure it is valid and checks if the user has the right permissions to perform the requested action.
- XML Processing: The app can handle IOF-XML v3 data, which is a standard format for organizing data. This is useful for uploading and downloading data about entries or results from different systems that use IOF-XML.
We will be using Node.js v20.17.0 (current LTS). New JavaScript features (ES2015) are "enabled". Can be used with promises, ES6 generators and async/await using Babel.
Clone the git repo, install dependencies, and deploy database schema. To clone and run this application, you'll need Git and Node.js (which comes with npm) installed on your computer. For consistent development and deployment environments, this project specifies a required Node.js version in the .nvmrc file. It is recommended to manage your Node.js installation using Node Version Manager (nvm), which helps ensure that you are using the exact version of Node.js needed for this project. From your command line:
# Clone this repository
git clone https://github.com/martinkrivda/oricloud.git
# Go into the repository
cd oricloud
Create backend/.env from the template in backend/.env.example and fill in the credentials to your database and keys to 3rd party.
# Install dependencies
npm install
# Deploy database schema
npx prisma migrate deploy
npx prisma db seed
# Run the app
npm run start:dev
- Modify your
./prisma/schema.prisma
file to reflect the changes you want in your database schema. This could involve adding new models, updating existing models, or deleting models. For example, to add a new model:
model Post {
id Int @id @default(autoincrement())
title String
content String?
published Boolean @default(false)
author User @relation(fields: [authorId], references: [id])
authorId Int
}
- Generate Migration
npx prisma migrate dev --name your_migration_name
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
- Create your feature branch:
git checkout -b Feature/my-new-feature
- Commit your changes:
git commit -am 'Add some feature'
- Push to the branch:
git push origin Feature/my-new-feature
- Submit a pull request :D
In separate file CHANGELOG.md. Please keep a CHANGELOG.
This project adheres to Semantic Versioning.