Skip to content

Atlas is an open-source platform for hosting CTF competitions, utilizing dynamic Docker orchestration to manage challenge environments. It offers an intuitive frontend, customizable admin panel, and a robust backend for seamless deployment and container management, ensuring a scalable and flexible CTF event experience.

License

Notifications You must be signed in to change notification settings

WebClub-NITK/atlas

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Atlas

Atlas is an open-source platform for hosting CTF competitions, utilizing dynamic Docker orchestration to manage challenge environments. It offers an intuitive frontend, customizable admin panel, and a robust backend for seamless deployment and container management, ensuring a scalable and flexible CTF event experience.

DB Diagram

dbdiagram

Setup

  1. Clone the repository

    git clone https://github.com/WebClub-NITK/atlas.git
  2. Environment Variables

  • Copy the example .env.example to a new .env file in the root directory

  • Fill in the required environment variables.

  • Example .env file:

    DB_USER=postgres
    DB_PASSWORD=postgres
    DB_NAME=postgres_db
  1. Build and run the docker containers

    docker-compose up --build

Coding Guidelines

Comments

  • Use clear and concise comments to explain the purpose of complex code blocks. For example, # Calculate the total price including tax.
  • Avoid redundant comments that state the obvious, such as # Increment i by 1.
  • Use docstrings for functions and classes to describe their purpose, parameters, and return values. Example:
    def fetch_user_data(user_id):
        """
        Fetches user data from the API.
        
        Args:
            user_id (str): The ID of the user.
        
        Returns:
            dict: The user data.
        """

Code Style

  • Use 4 spaces for indentation.
  • Prefer import statements at the top of the file.
  • Use meaningful and descriptive names for variables and functions, such as calculate_total_price.
  • Ensure consistent use of single quotes for strings, like 'Hello, World!'.
  • Place opening braces on the same line as the statement, e.g., if True:.

Variable Style

  • Use snake_case for variable and function names, e.g., user_name.
  • Use PascalCase for class names, e.g., UserProfile.
  • Use UPPER_SNAKE_CASE for constants, e.g., API_URL.
  • Choose meaningful and descriptive names for variables and functions, such as calculate_total_price.

Commit Style

  • Write clear and concise commit messages.
  • Use the present tense, e.g., Add feature not Added feature.
  • Capitalize the first letter of the commit message.
  • Use imperative mood, e.g., Fix bug not Fixed bug.
  • Include a brief description of the changes made.
  • Reference relevant issue numbers in the commit message.
  • Use prefixes like fix:, feat:, frontend:, backend:, misc: to categorize commits.

Development Style

  • Use feature branches for new features and bug fixes. For example, feature/add-user-authentication.
  • Keep the main branch in a deployable state.
  • Regularly pull changes from the main branch to keep your branch up to date.
  • Perform code reviews and seek feedback from team members.

About

Atlas is an open-source platform for hosting CTF competitions, utilizing dynamic Docker orchestration to manage challenge environments. It offers an intuitive frontend, customizable admin panel, and a robust backend for seamless deployment and container management, ensuring a scalable and flexible CTF event experience.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published