webapp/README.md

58 lines
2.3 KiB
Markdown
Raw Normal View History

2023-12-06 08:53:37 +00:00
# KevaChat Web Application
2023-12-06 08:45:50 +00:00
2023-12-06 08:57:40 +00:00
KevaChat is distributed web chat platform for open, uncensored and privacy respectable communication with permanent database storage in blockchain.
2023-12-06 08:45:50 +00:00
2023-12-06 20:15:11 +00:00
![KevaChat](https://github.com/kevachat/webapp/assets/108541346/9b286719-eafe-443f-a6e3-4b4927edde96)
2023-12-06 08:47:42 +00:00
2023-12-06 08:53:37 +00:00
## Tech
2023-12-06 20:16:19 +00:00
Instance require connection to the [Kevacoin](https://github.com/kevacoin-project/) wallet, `memcached` server and [Symfony](https://github.com/symfony/symfony) for web interface.
2023-12-06 08:45:50 +00:00
## Model
2023-12-06 08:53:37 +00:00
KevaChat following open wallet model, where community boost shared ballance for talks.
2023-12-06 08:45:50 +00:00
Administrators have flexible settings of access levels explained in the `.env` file: read-only rooms, connection and post limits, etc.
## Communication
Everyone able to join the chat, post messages as ghosty or sign ownership by IP. Also users can explore remote rooms by namespaces if option enabled.
Basic social features like identicons, replies, mentions, RSS subscriptions etc are supported.
## Protocol
KevaChat protocol following native Kevacoin's `key`/`value` model, where `key` - is the `timestamp@username` and `value` - is message.
All messages related to their room `namespaces`.
2023-12-06 23:53:24 +00:00
## Install
### Production
`composer create-project kevachat/webapp KevaChat`
### Development
* `git clone https://github.com/kevachat/webapp.git KevaChat`
* `cd KevaChat`
* `composer install`
2023-12-07 01:47:12 +00:00
## Setup
Application package contain settings preset, just few steps required to launch:
* Make sure `memcached` server enabled
* Setup Kevacoin server connection with `rpcuser`/`rpcpassword` in `~/.kevacoin/kevacoin.conf`
* Copy `rpcuser` to `env`.`APP_KEVACOIN_USERNAME` and `rpcpassword` to `env`.`APP_KEVACOIN_PASSWORD`
* Generate new address using CLI `kevacoin-cli getnewaddress` and copy to `env`.`APP_KEVACOIN_BOOST_ADDRESS`
* Send few coins to this address and wait for new block to continue
* Create namespace for the chat room with `kevacoin-cli keva_namespace "sandbox"` and add it hash to `env`.`APP_KEVACOIN_ROOM_NAMESPACES`
* Also Provide at least one namespace for default chat room to `env`.`APP_KEVACOIN_ROOM_NAMESPACE_DEFAULT` (for homepage redirects)
2023-12-06 08:45:50 +00:00
## Contribution
2023-12-07 01:49:52 +00:00
Project created by people for people: MIT License to use it for other needs e.g. new fork, chat instance or Kevacoin blockchain explorer.
2023-12-07 01:47:12 +00:00
Join the development and make your feedback!