Skip to content

Latest commit

 

History

History
164 lines (117 loc) · 6.78 KB

README.md

File metadata and controls

164 lines (117 loc) · 6.78 KB

File Sync

Frontend Build & Test Status Backend Build & Test Status TCP over UDP Build & Test Status

File Sync is a full-stack application that enables file transfer between two endpoints using a custom TCP-like protocol over UDP. The application consists of a React frontend and a Spring Boot backend, with C binaries for handling low-level TCP-like file transfer over UDP.

Related Repository

This project relies on the TCP-like protocol over UDP provided by the tcp-over-udp repository. This repository contains the core C code for the sender and receiver binaries used in file transfers.

Project Structure

file-sync/
├── backend/                           # Spring Boot backend
│   ├── .env                           # Environment variables for AWS credentials
│   ├── src/
│   │   ├── main/
│   │   │   ├── java/
│   │   │   │   └── com/networking/filetransfer/
│   │   │   │       ├── FileTransferApplication.java   # Main Spring Boot application class
│   │   │   │       ├── controller/
│   │   │   │       │   └── FileController.java        # REST controller
│   │   │   │       ├── service/
│   │   │   │       │   ├── FileTransferService.java   # Service for transfer logic
│   │   │   │       │   └── S3FileStorageService.java  # Service for S3 storage interactions
│   │   │   │       └── utils/
│   │   │   │           └── TransferExecutor.java      # Executes sender and receiver binaries
│   │   └── resources/
│   │       └── application.properties                 # Spring Boot configurations
│   ├── tcpOverUdp/                    # Directory for C binaries
│   │   ├── sender.c                   # Sender implementation
│   │   ├── receiver.c                 # Receiver implementation
│   │   └── Makefile                   # Compiles sender and receiver
│   └── build.gradle                   # Gradle dependencies and build configuration
├── frontend/                          # React frontend
│   ├── public/
│   ├── src/
│   │   ├── App.js                     # Main React component
│   │   └── components/                # UI components for specific pages and functionalities
│   │       ├── SenderPage.js          # Component for the sender page
│   │       ├── ReceiverPage.js        # Component for the receiver page
│   │       ├── UploadPage.js          # Component for S3 file upload
│   │       └── DownloadPage.js        # Component for S3 file download
│   └── package.json                   # React project dependencies and scripts
├── .gitignore                         # Root .gitignore
└── README.md                          # Project overview and setup instructions

Sender, Receiver, Upload, and Download Pages

Sender Page Receiver Page
Upload Page Download Page

Getting Started

This project requires Node.js for the frontend, Java 17 with Gradle for the backend, and GCC to compile the C binaries for TCP-like functionality over UDP.

Environment Setup for AWS

For Amazon S3 file storage, set up a .env file in the backend directory with your AWS credentials and region:

# backend/.env
AWS_ACCESS_KEY_ID=your-access-key-id
AWS_SECRET_ACCESS_KEY=your-secret-access-key
AWS_REGION=your-aws-region

Note: The .env file is included in .gitignore to keep credentials secure.

1. Set Up the Backend

  1. Navigate to the backend directory:

    cd backend
  2. Compile the TCP-like Binaries:

    • Go to the tcpOverUdp directory:

      cd tcpOverUdp
    • Run make to compile the sender and receiver binaries:

      make
    • Ensure the binaries are executable:

      chmod +x sender receiver
  3. Configure and Run the Spring Boot Application:

    • Go back to the backend root directory:

      cd ..
    • Run the backend:

      ./gradlew bootRun
    • The backend should start on http://localhost:8080.

For detailed backend setup and usage, see the backend README.

2. Set Up the Frontend

  1. Navigate to the frontend directory:

    cd ../frontend
  2. Install Dependencies:

    npm install
  3. Run the React Application:

    npm start

For detailed frontend setup and usage, see the frontend README.

Features

  • File Sending: Send files to a specified receiver over a custom TCP-like protocol using UDP.
  • File Receiving: Initiate a file transfer from the receiver endpoint, save the file locally, and download it via the frontend.
  • S3 Integration: Upload and download files from Amazon S3 for secure storage using S3FileStorageService.

Usage

  1. Sender: Access the "Sender" page in the React app, where you can specify the file, receiver hostname, port, and byte transfer limit.
  2. Receiver: Access the "Receiver" page to enter the port, desired filename, and file storage location, then start the receiver process.
  3. Upload to S3: Navigate to the "Upload" page, select a file, enter the bucket name and desired file name, then upload it to S3.
  4. Download from S3: Access the "Download" page to specify the bucket name and file name, and download the file from S3.

Additional Resources