Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lamdav/commujukebox
Curate a list of videos to watch or listen to
https://github.com/lamdav/commujukebox
chat jukebox react slack
Last synced: 13 days ago
JSON representation
Curate a list of videos to watch or listen to
- Host: GitHub
- URL: https://github.com/lamdav/commujukebox
- Owner: lamdav
- Created: 2018-12-15T23:41:12.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2018-12-15T23:47:02.000Z (about 6 years ago)
- Last Synced: 2025-01-11T08:56:29.747Z (16 days ago)
- Topics: chat, jukebox, react, slack
- Language: JavaScript
- Size: 174 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# CommuJukeBox
The Community Jukebox## Description
Build a community video playlist. Currently set up to be integrated with Slack; however, for other messaging platform,
an endpoint `/api/{platform}` needs to be implemented with proper validation and pass the video link to play and a way to uniquely
identify the user who requested it.Using a messenging platform like Slack, a user can send a video link to the backend service which will be routed to a central consumer
for broadcasting on a larger screen.## Features
- [x] Slack Integration
- [ ] Other chat integration (Pull Requests are welcome)
- [x] User Request Throttling (5 minutes)
- [x] Administrative Queueing Endpoint to bypass Throttling
- [x] Validate Youtube videos## Setup
1. Clone the repo: `git clone https://github.com/lamdaV/CommuJukeBox.git`
2. Change into the repo directory: `cd CommuJukeBox`
3. Install dependencies: `yarn install` or `npm install`
4. Create Slack workspace or use an existing one
5. Create a Slack [app](https://api.slack.com/apps)
6. Create .env file with values filled out:
```
NODE_ENV=production # state of deployment
HOST=localhost # host of api server
SERVER_PORT=8080 # port of api server
PRIVILEDGED_USER=changeme # just a specific username for the administrative user
PRIVILEDGED_TOKEN=changeme # secret used to authenticate administrative endpointSLACK_VERSION=v0 # slack schema version used to verify requests
SLACK_VERIFICATION_SECRET=changeme # slack verification secret used to verify requestsREACT_APP_IO_HOST=localhost # socket.io host for frontend to connect to
REACT_APP_IO_PORT=8081 # socket.io port for frontend to connext to
```
7. Build frontend: `yarn build`
8. Start server: `yarn serve`
9. Install [ngrok](https://ngrok.com/)
10. Start ngrok in separate terminal window: `ngrok http {SERVER_PORT}` (SERVER_PORT from .env)
11. Create a Slack `Slash commands` and point it to the provided ngrok tunnel endpoint and append `/api/slack`
12. In a different tab or window, go to `localhost:{SERVER_PORT}` and you should see a simplistic frontend
13. Return to Slack and type the Slash command you created with a Youtube link: `/play youtube.com/watch?v={videoId}`
14. A video should start playing `localhost:{SERVER_PORT}`## Contributing
Want to add support for other chat applications? Create an endpoint `/api/{chatApplicationName}` and handle any verification
process possible for that chat application.Want to add support for videos other than YouTube? Improve the existing URL verification to support other videos or improve
the existing YouTube url verification.Any features or improvements are welcome!