KevaChat is distributed chat platform for open, uncensored and privacy respectable communication with permanent data storage in blockchain.
Go to file
2023-12-07 18:40:24 +02:00
bin init symfony framework 2023-12-04 21:28:33 +02:00
config add monolog-bundle 2023-12-07 00:14:17 +02:00
public increase margin 2023-12-06 22:01:42 +02:00
src fix link 2023-12-06 23:54:01 +02:00
templates/default fix css location 2023-12-07 18:29:48 +02:00
translations complete feed feature 2023-12-05 17:14:07 +02:00
.env update version 2023-12-07 18:30:08 +02:00
.gitignore remove locks 2023-12-07 04:05:46 +02:00
composer.json update php requirements 2023-12-07 02:02:48 +02:00
composer.lock update composer lock 2023-12-07 18:40:24 +02:00
LICENSE Initial commit 2023-12-04 21:15:35 +02:00
README.md update readme 2023-12-07 03:49:52 +02:00
symfony.lock remove locks 2023-12-07 04:05:46 +02:00

KevaChat Web Application

KevaChat is distributed web chat platform for open, uncensored and privacy respectable communication with permanent database storage in blockchain.

KevaChat

Tech

Instance require connection to the Kevacoin wallet, memcached server and Symfony for web interface.

Model

KevaChat following open wallet model, where community boost shared ballance for talks.

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.

Install

Production

composer create-project kevachat/webapp KevaChat

Development

  • git clone https://github.com/kevachat/webapp.git KevaChat
  • cd KevaChat
  • composer install

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)

Contribution

Project created by people for people: MIT License to use it for other needs e.g. new fork, chat instance or Kevacoin blockchain explorer.

Join the development and make your feedback!