Skip to content

dhanrajchaurasia/CP-Grind

Repository files navigation

CP-GRIND

Table of Contents

Introduction

This project is a RESTful API built using the Golang web framework Fiber and PostgreSQL as the database. It provides a foundation for building and deploying RESTful web services. You can use this project as a starting point for creating your own APIs or as a learning resource for Golang and PostgreSQL integration.

Features

  • Integration with Codeforces and AtCoder APIs: This project leverages the Codeforces and AtCoder APIs to retrieve contest data, user information, and other related data. It fetches data from these platforms, processes it, and exposes it through RESTful APIs.
  • Data Modification and Presentation: The project not only fetches data from Codeforces and AtCoder but also allows you to modify and present the data in a customized way through its RESTful endpoints.
  • Flexible and Extendable: You can easily extend the functionality of this project to integrate with other APIs or add additional features to suit your specific needs.

You can use this project to build applications that interact with competitive programming platforms, analyze contest statistics, or create personalized dashboards for users participating in coding competitions.

Prerequisites

Before you begin, ensure you have met the following requirements:

  • Golang: Install Golang on your system.
  • PostgreSQL: Install PostgreSQL and create a database for this project.
  • Git: Install Git for version control.

Installation

Follow these steps to set up and run the project:

  1. Clone the repository:

    git clone https://github.com/ContriHUB/CP-Grind.git
  2. Change to the project directory:

    cd CP-Grind
  3. Install project dependencies using Go Modules:

    go mod tidy
  4. Set up your environment variables. Create a .env file in the project root and add the following configuration, replacing the values with your own:

    # Database Configuration
    DATABASE_URL = "host=localhost user=<Database Username> password=<Database Password> dbname=<Database Name> port=<Database Port>"
    # Fiber Configuration
    PORT=3000
  5. Migrate the database to create the necessary tables:

    go run migrate.go
  6. Start the application:

    go run main.go

Configuration

You can configure the application by modifying the .env file with your own settings. Additionally, you can customize other aspects of the application by editing the relevant code files.

Usage

After successfully setting up the project, you can start using the RESTful API. You can use tools like Postman or curl to interact with the API.

Contributing

We welcome contributions to this project. If you have any bug fixes, enhancements, or new features to propose, please open a pull request. For major changes, please open an issue first to discuss the changes you want to make.

License

This project is licensed under the MIT License.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published