Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/minetest/contentdb
A content database for Minetest mods, games, and more
https://github.com/minetest/contentdb
hacktoberfest minetest mod restful-api website
Last synced: 5 days ago
JSON representation
A content database for Minetest mods, games, and more
- Host: GitHub
- URL: https://github.com/minetest/contentdb
- Owner: minetest
- License: agpl-3.0
- Created: 2018-03-18T17:07:27.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-12-24T09:29:42.000Z (29 days ago)
- Last Synced: 2025-01-10T22:13:07.380Z (12 days ago)
- Topics: hacktoberfest, minetest, mod, restful-api, website
- Language: Python
- Homepage: https://content.minetest.net
- Size: 20.3 MB
- Stars: 98
- Watchers: 11
- Forks: 47
- Open Issues: 69
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
# ContentDB
![Build Status](https://github.com/minetest/contentdb/actions/workflows/test.yml/badge.svg)A content database for Minetest mods, games, and more.\
Developed by rubenwardy, license AGPLv3.0+.See [Getting Started](docs/getting_started.md) for setting up a development/prodiction environment.
See [Developer Intro](docs/dev_intro.md) for an overview of the code organisation.
## Credits
* `app/public/static/placeholder.png`: erlehmann, Warr1024. License: CC BY-SA 3.0
## How-tos
```sh
# Hot/live reload (only works with FLASK_DEBUG=1)
./utils/reload.sh# Cold update a running version of CDB with minimal downtime (production)
./utils/update.sh# Enter docker
./utils/bash.sh# Run migrations
./utils/run_migrations.sh# Create new migration
./utils/create_migration.sh# Delete database
docker-compose down && sudo rm -rf data/db
```### VSCode: Setting up Linting
* (optional) Install the [Docker extension](https://marketplace.visualstudio.com/items?itemName=ms-azuretools.vscode-docker)
* Install the [Python extension](https://marketplace.visualstudio.com/items?itemName=ms-python.python)
* Click no to installing pylint (we don't want it to be installed outside a virtual env)
* Set up a virtual env
* Replace `psycopg2` with `psycopg2_binary` in requirements.txt (because postgresql won't be installed on the system)
* `python3 -m venv env`
* Click yes to prompt to select virtual env for workspace
* Click yes to any prompts about installing pylint
* `source env/bin/activate`
* `pip install -r requirements`
* `pip install pylint` (if a prompt didn't appear)
* Undo changes to requirements.txt### VSCode: Material Icon Folder Designations
```json
"material-icon-theme.folders.associations": {
"packages": "",
"tasks": "",
"api": "",
"meta": "",
"blueprints": "routes",
"scss": "sass",
"flatpages": "markdown",
"data": "temp",
"migrations": "archive",
"textures": "images",
"sounds": "audio"
}
```## Database
```mermaid
classDiagramUser "1" --> "*" Package
User --> UserEmailVerification
User "1" --> "*" Notification
Package "1" --> "*" Release
Package "1" --> "*" Dependency
Package "1" --> "*" Tag
Package "1" --> "*" MetaPackage : provides
Release --> MinetestVersion
Package --> License
Dependency --> Package
Dependency --> MetaPackage
MetaPackage "1" --> "*" Package
Package "1" --> "*" Screenshot
Package "1" --> "*" Thread
Thread "1" --> "*" Reply
Thread "1" --> "*" User : watchers
User "1" --> "*" Thread
User "1" --> "*" Reply
User "1" --> "*" ForumTopicUser --> "0..1" EmailPreferences
User "1" --> "*" APIToken
APIToken --> Package
```