Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rtippin/messenger-demo

Laravel messenger demo app using rtippin/messenger. Private and group threads with real-time messaging, reactions, attachments, calling, chat bots, and more!
https://github.com/rtippin/messenger-demo

chat-application friends group-threads laravel live-chat messenger messenger-demo realtime-chat realtime-messaging

Last synced: about 4 hours ago
JSON representation

Laravel messenger demo app using rtippin/messenger. Private and group threads with real-time messaging, reactions, attachments, calling, chat bots, and more!

Awesome Lists containing this project

README

        

# [Messenger Demo App](https://github.com/RTippin/messenger)

![Preview](public/examples/image1.png?raw=true)

---

## Included addon packages:
- UI / Web routes [messenger-ui](https://github.com/RTippin/messenger-ui)
- Ready-made bots [messenger-bots](https://github.com/RTippin/messenger-bots)
- Faker commands [messenger-faker](https://github.com/RTippin/messenger-faker)
- Janus media server client [janus-client](https://github.com/RTippin/janus-client)

## Checkout the [LIVE DEMO](https://tippindev.com)

### Prerequisites
- PHP >= 8.0.2
- Laravel >= 9.x
- MySQL >= 8.x
- [PHPREDIS](https://github.com/phpredis/phpredis/blob/develop/INSTALL.markdown) if using `redis` for drivers, which our default `.env.example` has set.

### Notes
- This demo is meant to be seeded before use. Registration also assumes a pre-seeded database, as we automatically create threads between the admin user and a newly registered user, as well as set friendships.
- Calling will be disabled by default. Even though we have our [janus-client](https://github.com/RTippin/janus-client) installed, you are responsible for setting up your own `Janus Server`.
- Please see [Janus official docs](https://janus.conf.meetecho.com/docs/index.html) for more information.
- We use `pusher.com` by default for our websocket implementation, however you may choose to use the drop-in replacement [laravel-websockets](https://beyondco.de/docs/laravel-websockets/getting-started/introduction)

---

# Installation

#### Clone or download this repository
```bash
git clone [email protected]:RTippin/messenger-demo.git
```

#### Composer install
```bash
composer install
```

#### Rename the `.env.example` to `.env` and configure your environment, including your pusher keys if you use pusher.
```dotenv
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=1234
DB_DATABASE=demo
DB_USERNAME=root
DB_PASSWORD=password
PUSHER_APP_ID=
PUSHER_APP_KEY=
PUSHER_APP_SECRET=
PUSHER_APP_CLUSTER=
MESSENGER_SOCKET_PUSHER=true
MESSENGER_SOCKET_KEY="${PUSHER_APP_KEY}"
MESSENGER_SOCKET_CLUSTER="${PUSHER_APP_CLUSTER}"
#etc
```

#### Run the Install Command
- This command will generate your `APP_KEY` for you, as well as migrating fresh and downloading our documentation files.
- This will `WIPE` any data in your database as it runs `migrate:fresh` under the hood.
```bash
php artisan demo:install
```

---

## Running locally:

#### Run these commands in their own terminal inside your project folder
```bash
php artisan serve
php artisan queue:work --queue=messenger,messenger-bots
```

---

## Default seeded admin account:

### Email `[email protected]`

### Password: `messenger`

### All other seeded accounts use `messenger` password as well

---

## UI configurations / Websockets
- If you plan to use [laravel-websockets](https://beyondco.de/docs/laravel-websockets/getting-started/introduction), or want more information regarding our UI, please visit our documentation:
- [Messenger UI README](https://github.com/RTippin/messenger-ui/blob/master/README.md)

---

# Pictures

### Sending images, voice messages, replies, and reactions
![Preview](public/examples/image1.png?raw=true)

---

### Interacting with a chat-bot using triggers to invoke responses
![Preview](public/examples/image2.png?raw=true)

---

### Viewing a bots actions and triggers
![Preview](public/examples/image3.png?raw=true)

---

### Managing a groups participants
![Preview](public/examples/image4.png?raw=true)

---

### In a video call
![Preview](public/examples/image5.png?raw=true)

---

### Sending documents and images, hovering over options / reactions
![Preview](public/examples/image6.png?raw=true)