luanti-g1/README.md
2025-06-12 20:10:41 +02:00

65 lines
2.7 KiB
Markdown

# Ğ1 <-> Luanti bridge
Luanti mod to exchange in-game [currency](https://github.com/mt-mods/currency) with [libre currency](https://duniter.org) (Ğ1 blockchain).
Luanti server has a dedicated account.
Player transfer money on it and the server gives them a corresponding amount of in-game banknotes.
They can then do whatever they want with the banknotes (trade, decorate walls, burn...).
Players can ask the server to transfer their banknotes to an account of their choice using a chat command.
It works with Ğ1v2 which is still in development/testing phase.
## Install
Put this repo in the `mods` directory.
Have a local Duniter node.
```bash
cargo build --release
./target/release/g1bridge -l -d /path/to/database -s ../sk
```
* `sk` contains the server's secret key
* Without `-l`, use Substrate formats.
* With `-l`, use legacy Ğ1 format on 2 lines (one password per line).
* `database` is the directory where the bridge will save its database. It is used to store debts in case of failure of a transfer.
## ToDo
* Blockchain-to-game transfers
* Ensure all transfers are failproof (any communication, storage medium, server or whatever should be able to fail or rollback to a previous state, without causing double spend or money loss)
* Force reception account to exist
* Nice ATM-like interface
## Workflow
### game -> blockchain
1. Player issues command `/g1_send <amount> <address>`
2. Mod takes currency from inventory and saves the debt in storage.
3. Mod sends `/send/<address>/<amount>` to bridge.
4.
* If bridge responds immediately, clean the debt.
* Else, retry later.
### blockchain -> game
1. bridge listens to events
2. on reception event, bridge stores debt
3. Player issues command `/g1_claim`
4. Mod sends `/claim/<player>` to bridge
5. Bridge answers an amount and clears debt
6. Mod stores debt
7. Mod tries to give player MG
8. What does not fit is kept in debt. What does fit is removed from debt.
## License
[Support me via LiberaPay](https://liberapay.com/tuxmain/donate)
GNU AGPL v3, CopyLeft 2025 Pascal Engélibert [(why copyleft?)](https://txmn.tk/blog/why-copyleft/)
This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, version 3 of the License.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.