Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sauldoescode/paka
basic encrypyed file system access via tokens made with an admin/encryption password.
https://github.com/sauldoescode/paka
actix-web encryption fileserver rust self-hosted tokens
Last synced: 5 days ago
JSON representation
basic encrypyed file system access via tokens made with an admin/encryption password.
- Host: GitHub
- URL: https://github.com/sauldoescode/paka
- Owner: SaulDoesCode
- License: mit
- Created: 2023-06-15T10:24:53.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2023-10-24T19:23:19.000Z (about 1 year ago)
- Last Synced: 2024-11-09T14:49:37.192Z (2 months ago)
- Topics: actix-web, encryption, fileserver, rust, self-hosted, tokens
- Language: Rust
- Homepage:
- Size: 137 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Paka Server Documentation
This documentation provides an overview and explanation of a Rust server implemented using Actix Web framework. The server is responsible for generating tokens, managing files, and serving static content.
## Table of Contents
- [Server Structure](#server-structure)
- [API Endpoints](#api-endpoints)
- [Token Generation](#token-generation)
- [File Management](#file-management)
- [Static Content Serving](#static-content-serving)
- [Authentication](#authentication)
- [Configuration](#configuration)## Server Structure
The Paka server is built using Actix Web, which is a lightweight and powerful web framework. It follows a modular structure and consists of the following main components:
- **Main Function**: The entry point of the server, which initializes the Actix Web application and starts the server.
- **Routes**: Defined using the `actix-web` macros, these routes map to different HTTPs (rustls, not RSA) endpoints and handle incoming requests.
- **Token Generation**: Handles the generation and encryption of tokens used for authentication and file access.
- **File Management**: Manages the uploading, downloading, and deletion of files on the server.
- **Static Content Serving**: Handles the serving of static files such as HTML, CSS, JavaScript, and images.
- **Authentication**: Verifies the validity of tokens for accessing protected endpoints.
- **Configuration**: Handles the configuration settings of the server, including admin password and file paths.## API Endpoints
The server exposes the following API endpoints:
- `POST /make-tokens/{count}`: Generates a specified number of tokens for authentication purposes.
- `POST /admin/change-password`: Changes the admin password.
- `GET /file-info/{filename}?tk=TOKENSTRING`: Retrieves information about a file.
- `POST /file/{filename}?tk=TOKENSTRING`: Uploads a file to the server.
- `GET /file/{filename}?tk=TOKENSTRING`: Downloads a file from the server.
- `DELETE /file/{filename}?tk=TOKENSTRING`: Deletes a file from the server.
- `GET /static/{filename}`: Serves static files such as HTML, CSS, JavaScript, and images.
- `GET /`: Serves the main index.html file.[paka-works.png](https://postimg.cc/kBQ4gTYP)
## Token Generation
The server provides a token generation functionality that allows the creation of tokens for authentication and file access. Tokens are generated using a POST request to the `/make-tokens/{count}` endpoint. The provided admin password is validated, and if correct, the specified number of tokens is generated and saved as files on the server. Tokens are valid for a day (timestamp code you can change it, will eventually make things configurable by less baked in means), and they are use once, the tokens that is.
tokens are hashed with sthash and the actual token you use it not saved on the server only its hash and meta-data, making it so that you can't read the token filenames and get free tokens.
TODO: figure out how to safely hide the admin_pwd so that it doesn't need to be a text file, perhaps should require password be given from an http event or something so that the data is essentially encrypted fully at rest. one pwd to rule them all. still thinking about it.
## File Management
The server enables file management functionalities, including file upload, download, and deletion. Files are uploaded using a POST request to the `/file/{filename}` endpoint, where the file is encrypted and saved on the server. Files can be downloaded using a GET request to the same endpoint, and deleted using a DELETE request.
## Static Content Serving
The server serves static files stored in the `./static` directory. When a GET request is made to the `/static/{filename}` endpoint, the corresponding file is served. If the file can be compressed (based on its MIME type), it is compressed and served with the appropriate Content-Encoding header.
## Authentication
To access protected endpoints, clients must include a valid token in the query parameters of the request. The token is validated by checking its existence and expiration time. If the token is valid, the client is granted access to the protected endpoint. Tokens are removed from the server after being used or if they expire.
## Configuration
The server allows configuration through the following settings:
- `ADMIN_PWD_FILE_PATH`: Path to the file storing the admin password.
- `TOKENS_DIR`: Directory where generated tokens are stored.
- `GZIPABLE_TYPES`: Array of MIME types that can be compressed when serving static files.The server initializes
with an admin password, which can be changed using the `/admin/change-password` endpoint. The admin password is stored in the `ADMIN_PWD_FILE_PATH` file.
This documentation provides an overview of the Paka server's structure and functionality. For more detailed information, refer to the comments in the code itself.
PORT is 8000, you must put a cert.pem and priv.pem into ./secrets/ or set where the equivalent might be by changing the constants in the main.rs file for now.
### Authentication Token Function
The authentication token function is responsible for verifying the validity of a given token. Here's an overview of what happens in this function:
1. The function receives a token as input.
2. It first checks if the token exists and is not empty. If the token is missing or empty, the authentication fails.
3. Next, the function decrypts the token to retrieve the payload, which contains information such as the token's creation time and expiration time.
4. The function checks if the token has expired by comparing the current Unix time (in seconds) with the expiration time stored in the payload.
5. If the token has expired, the authentication fails.
6. If the token is valid and has not expired, the authentication succeeds, and the function returns a boolean value indicating the result.### Token Making Route
The token-making route is responsible for generating tokens based on the specified count. Here's an overview of what happens in this route:
1. The route receives a POST request to the `/make-tokens/{count}` endpoint, where `{count}` is the desired number of tokens to generate.
2. The provided admin password is extracted from the request.
3. The admin password is compared against the stored admin password (usually read from the `ADMIN_PWD_FILE_PATH` file) to verify its correctness.
4. If the admin password is incorrect, the route returns an appropriate error response.
5. If the admin password is correct, the route generates the specified number of tokens.
6. Each token consists of a payload containing the creation time and expiration time. The creation time is set to the current Unix time (in seconds), and the expiration time is calculated by adding 3600 seconds (1 hour) to the creation time.
7. The tokens are then encrypted and saved as files on the server, typically in the `TOKENS_DIR` directory.
8. The route returns a success response indicating the number of tokens generated.The inclusion of the expiry check and the calculation involving Unix time is important for ensuring the security and validity of the generated tokens. By setting an expiration time, the tokens become valid only for a specific duration, reducing the risk of unauthorized access if a token is compromised.
## Building and Running the Paka Server
The Paka server is a Rust-based server that provides various functionalities such as token generation, file upload, and download. Follow the instructions below to build and run the Paka server.
### Prerequisites
Before building and running the Paka server, ensure that you have the following dependencies installed:
- Rust (stable version)
- Cargo (Rust's package manager)### Step 1: Clone the Repository
1. Open your terminal or command prompt.
2. Change the current directory to the location where you want to clone the repository.
3. Run the following command to clone the repository:```bash
git clone SaulDoesCode/paka
```### Step 2: Navigate to the Project Directory
1. Change the current directory to the cloned repository's directory:
```bash
cd paka
```### Step 3: Build the Paka Server
1. Run the following command to build the Paka server:
```bash
cargo build --release
```This command compiles the server code and its dependencies, creating an optimized release build.
### Step 4: Run the Paka Server
1. After successful build, run the following command to start the Paka server:
```bash
cargo run --release
```This command starts the server and binds it to the default address `0.0.0.0:8000`.
**Note:** If you want to bind the server to a specific address, modify the `bind` argument in the `HttpServer::bind` function call in the `main` function of the `main.rs` file before building the server.
2. The Paka server is now running and ready to accept incoming requests.### Step 5: Interacting with the Paka Server
1. Use an API testing tool (e.g., cURL, Postman) or a web browser to send HTTP requests to the Paka server.
- To generate tokens, send a POST request to `https://localhost:8000/make-tokens/{count}`, where `{count}` is the desired number of tokens to generate.
- To upload a file, send a POST request to `https://localhost:8000/file/{filename}` with the file contents in the request body.
- To download a file, send a GET request to `https://localhost:8000/file/{filename}`.
- For other available routes, refer to the server code or the provided documentation.
2. The server will respond to the requests based on the implemented functionality and authentication mechanisms.### Additional Notes
- The Paka server stores tokens and files in the specified directories (`TOKENS_DIR` and `./dist/`, respectively) relative to the server's execution location.
- You can customize various server configurations, such as the admin password file path and the types of files that should be compressed, by modifying the respective constants in the server's code.
- It is recommended to consult the server's code and comments for more detailed information about its functionality and configuration.That's it! You have successfully built and run the Paka server. Feel free to explore its various endpoints and functionalities as needed.
## FUTURE features and enbetterments
* finer grained perms on tokens
* websocket interface
* pub/sub
* quality errors and error handling## HELP OUT
[ko-fi.com/saulvdw]()