AniX/README.md

3.8 KiB

AniX - Unofficial Web Client for Anixart

AniX is an unofficial web client for the Android application Anixart. It allows you to access and manage your Anixart account from a web browser on your desktop or laptop computer.

Screenshots

user profile page user profile page image

main page main page image

Project Structure

This project consists of two main parts:

  1. Backend (Python with FastAPI): This handles communication with the Anixart API and provides data to the frontend.
  2. Frontend (Next.js): This is the user interface that you interact with in your web browser. It fetches data from the backend and displays it in a user-friendly way.

Disclaimer

Please note that AniX is an unofficial project and is not affiliated with the developers of Anixart. It is recommended to use the official Anixart app for the most up-to-date features and functionality.

Getting Started

The is a two ways to run this project locally. directly and via docker compose.

Docker

Docker Requirements

  • docker (>=26)
  • docker compose (>= 2.27)

Running the project via Docker

Execute docker compose -f docker-compose.dev.yml up command in the root of the folder.

You can access the AniX web client in your browser at http://127.0.0.1. And API docs at http://127.0.0.1/api/docs

Directly

Prerequisites

Setting Up the Backend

  1. Clone this repository.

  2. Navigate to the project directory in your terminal.

  3. Create a virtual environment to isolate project dependencies:

    python -m venv venv
    source venv/bin/activate  # For Linux/macOS
    venv\Scripts\activate.bat  # For Windows
    
  4. Install the required backend dependencies:

    pip install -r ./requirements.txt
    

Setting Up the Frontend

  1. Navigate to the frontend directory.

  2. Install the required frontend dependencies:

    npm install
    

Running the Project

  1. Start the backend server:

    cd ./backend
    source ./venv/bin/activate
    uvicorn main:app --reload
    
  2. Start the frontend development server:

    cd ./frontend
    npm run dev
    
  3. Start local traefik reverse proxy

    1. download a traefik binary from github
    2. place it in traefik directory and make it executable
    3. run sudo ./traefik --configFile ./traefik.yml

You can access the AniX web client in your browser at http://127.0.0.1. And API docs at http://127.0.0.1/api/docs

Development

To maintain code formatting it's recommended to use pre-commit hooks

  1. Install global pre-commit pip install pre-commit
  2. Install pre-commit hooks via pre-commit install inside repository folder

To maintain readable git commit messages it's recommended to use commitizen

Feel free to make changes and experiment with the project.

Docker development environment

To run development environment via docker you can execute the docker watch command, it will watch and copy local changes in to the running container. you will need to use the dev compose file and docker files.

Execute the docker compose -f docker-compose.dev.yml watch command to set up the docker development environment.

To access the docker logs you can use docker compose -f docker-compose.dev.yml logs -f command.

Deployment

Docker Deployment

To be added soon . . .

Deta Space

To be added soon . . .

Contributing

We welcome contributions to this project! If you have any bug fixes, improvements, or new features, please feel free to create a pull request.