Repository for a course project of CS4675/CS6675 at Georgia Institute of Technology.
- Please do not commit any code to the main branch directly
- Use feature branches, ideally with your name and the feature it is for mentioned in the branch name eg. feature_aman_login
- Raise a PR once you are ready and have checked your code for errors.
- Mention a bullet point summary for all the features you are pushing as part of the PR within the description to ease the review process
-
Create a new branch:
git checkout -b <branch-name>
-
Make your changes.
-
Use black to format your code: (With virtual environment activated)
black .
-
Make your changes and commit them:
git add . git commit -m "Your commit message"
-
Push your changes to the remote repository:
git push origin <branch-name>
-
Create a Pull Request on GitHub.
For our frontend we are using React + Vite + TypeScript!
- React -> JavaScript Framework for creating reactive user interfaces.
- Vite -> Development environment / build tool. Gives us access to features like hot reload, bundling, and plugins.
- TypeScript -> A superset of JavaScript allowing for static types.
Here's how to set up + run the frontend environment:
- Download and install Node.js v18+ Check your node version:
node -v
- Clone the repo using Git
- Install dependencies
cd frontend
npm install
- Start the development server
npm run dev
- Visit http://localhost:5173
This is the backend for the Django project.
-
Open a new terminal and cd into the backend directory:
cd backend
-
Create a virtual environment:
python3 -m venv venv
-
Activate the virtual environment:
- For macOS/Linux:
source venv/bin/activate
- For Windows:
venv\Scripts\activate
- For macOS/Linux:
-
Install the project dependencies:
pip install -r requirements.txt
To start the Django server, run the following command:
python3 manage.py runserver
By default, the server will run on http://localhost:8000/
.
In order to access the admin panel, you need to create a superuser. To do this, run the following command:
python3 manage.py createsuperuser
Then, you can access the admin panel by visiting http://localhost:8000/admin/
and logging in with the superuser credentials.
This is the service which runs on the client side and is responsible for handling the peer to peer connections and file transfers along with getting the IPs of the machine. In order to run this, please do the following:
-
Open a new terminal and cd into the file_peer directory:
cd file_peer
-
Make sure that the venv that we used for the backend service is activated
-
Run the flask server using the following command:
python3 peer_service.py
- You would need to set up the central server with a domain and change the domain within the client code. (It is currently hardcoded with IP.)
- Make sure all the servers are running within the same network as this solution is featured to be restricted to within a network by design.