Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/anthhon/vodka
Lightweight web framework written in pure C.
https://github.com/anthhon/vodka
Last synced: about 2 months ago
JSON representation
Lightweight web framework written in pure C.
- Host: GitHub
- URL: https://github.com/anthhon/vodka
- Owner: Anthhon
- License: mit
- Created: 2024-01-19T19:36:32.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-03-03T15:09:12.000Z (10 months ago)
- Last Synced: 2024-03-03T16:26:38.452Z (10 months ago)
- Language: C
- Homepage:
- Size: 62.5 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Vodka
This is a (until now) simple and light-weight framework made in C. I don't
recommend using it for professional purposes but if you want to have some fun,
move on and try it! The project goal is to be as easy to use as Django with
the pure C speed.# Usage
To use the project just use these commands:
```bash
git clone [email protected]:Anthhon/Vodka.git
cd Vodka
make build-linux -B # Doesn't have a proper Windows build command
cd build# Change your 'src/config.c' file before running
./Vodka run
```# Features
- Handle all HTTP methods
- [X] GET requests
- [ ] POST requests
- [ ] PUT requests
- [ ] DELETE requests
- Handle all file type
- [X] HTML files
- [X] CSS files
- [X] JS files
- [ ] CSV files
- [ ] Media files (MP4, PNG, WEBM...)
- Caching
- [ ] Session management
- [ ] File reading cache
- [X] Http caching (made by browser)
- [X] Allow user to add custom URLs
- [X] Handle 404 errors
- [X] Thread-pool to handle multiple requests
- [X] Logging system to track and record events for debugging
- [ ] Requests rate limiting from single client
- Support for `config.properties` file type
- [X] Reading and parsing info from `.properties` file
- [ ] Updating server info dynamically
- [ ] Support for HTTPS (SSL/TLS)
- [ ] Templating system# Contributing
Contributions to the project would be really appreciated. Talking about your
wanted features or changes in the [Issues](/issues) tab would be appreciated.
Besides that, fork the project and do whatever you want!# License
This project is licensed under the MIT License - see the [LICENSE](/LICENSE)
file for details.