Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matrix-hacks/matrix-puppet-slack
puppet style slack bridge for matrix
https://github.com/matrix-hacks/matrix-puppet-slack
bridge matrix slack
Last synced: about 2 months ago
JSON representation
puppet style slack bridge for matrix
- Host: GitHub
- URL: https://github.com/matrix-hacks/matrix-puppet-slack
- Owner: matrix-hacks
- Created: 2017-01-06T19:37:02.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2022-06-11T19:19:43.000Z (over 2 years ago)
- Last Synced: 2024-06-26T11:36:41.295Z (7 months ago)
- Topics: bridge, matrix, slack
- Language: JavaScript
- Size: 147 KB
- Stars: 47
- Watchers: 6
- Forks: 17
- Open Issues: 36
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-matrix - matrix-puppet-slack
README
# matrix-puppet-slack [![#matrix-puppet-bridge:matrix.org](https://img.shields.io/matrix/matrix-puppet-bridge:matrix.org.svg?label=%23matrix-puppet-bridge%3Amatrix.org&logo=matrix&server_fqdn=matrix.org)](https://matrix.to/#/#matrix-puppet-bridge:matrix.org)
This is an unofficial matrix slack bridge that works by means of [user puppetting](https://github.com/AndrewJDR/matrix-puppet-bridge).
Get your `user_access_token` from here:
https://api.slack.com/docs/oauth-test-tokens
The bridge uses that access token to connect as a client using the slack RTM API.
This technique does not require admin on the slack team; instead, the bridge is simply a custom slack client.
The bridge supports multiple teams at once, see the config.sample.json
## installation
clone this repo
cd into the directory
run `npm install`
## configure
Copy `config.sample.json` to `config.json` and update it to match your setup. Add as many teams as you like by adding them to the array.
If you are running another bridge that uses the default `slack` prefix, change the prefix now. **You cannot change this value after the bridge has created rooms and ghost users.**
## register the app service
Generate an `slack-registration.yaml` file with `node index.js -r -u "http://your-bridge-server:8090"`
Note: The 'registration' setting in the config.json needs to set to the path of this file. By default, it already is.
Copy this `slack-registration.yaml` file to your home server. Make sure that from the perspective of the homeserver, the url is correctly pointing to your bridge server. e.g. `url: 'http://your-bridge-server.example.org:8090'` and is reachable.
Edit your homeserver.yaml file and update the `app_service_config_files` with the path to the `slack-registration.yaml` file.
Launch the bridge with ```node index.js```.
Restart your HS.
## docker
Build the docker image with `docker build -t matrix-puppet-slack .`.
Copy `config.sample.json` to `config.json` and update it to match your setup.
You can work in any directory you want as you have the docker image now.
Set the `registrationPath` in the `config.json` to `/data/slack-registration.yaml`.Generate the `slack-registration.yaml` file in the data volume with ``docker run --rm -it -v `pwd`/data:/data -v `pwd`/config.json:/usr/src/app/config.json matrix-puppet-slack node index.js -r -u "http://your-bridge-server:8090"``.
As discribed in [register the app service](#register-the-app-service)
copy the registration file to your homeserver and add it to your homeserver.yaml file.Launch the bridge with ``docker run -v `pwd`/data:/data -v `pwd`/config.json:/usr/src/app/config.json matrix-puppet-slack`` or via docker-compose.
## Discussion, Help and Support
Join us in the [![Matrix Puppet Bridge](https://user-images.githubusercontent.com/13843293/52007839-4b2f6580-24c7-11e9-9a6c-14d8fc0d0737.png)](https://matrix.to/#/#matrix-puppet-bridge:matrix.org) room
## Features and Roadmap
- [x] Multi-team
- [x] Channel messages
- [x] Direct messages
- [x] Recieving
- [ ] Initiating (https://github.com/matrix-hacks/matrix-puppet-slack/issues/50)
- Matrix -> Slack
- [x] Text content
- [x] Formatted Text content
- [x] Image content (m.image msgtype events)
- [x] Generic file uploads (m.file msgtype events)
- [ ] Audio (m.audio msgtype events) (https://github.com/matrix-hacks/matrix-puppet-slack/issues/66)
- [ ] Video content (m.video msgtype events) (https://github.com/matrix-hacks/matrix-puppet-slack/issues/67)
- [ ] Typing notifications
- [ ] Editing messages
- [ ] Redacting/deleting messages (https://github.com/matrix-hacks/matrix-puppet-slack/issues/52)
- [ ] User Profiles
- [ ] /me emotes (https://github.com/matrix-hacks/matrix-puppet-slack/issues/17)
- [x] @-mentions
- [x] @room, as @channel
- Slack -> Matrix
- [x] Text content
- [x] Formatted Text content
- [x] Image/Audio/Video content as protected link to slack
- [x] Image/Audio/Video content as upload & embed to matrix
- [x] Image/Audio/Video content message text
- [x] Typing notifications
- [ ] Emoji reactions (https://github.com/matrix-hacks/matrix-puppet-slack/issues/60)
- [x] Thread replies, as ordinary messages
- [ ] Thread replies, as Matrix replies (https://github.com/matrix-hacks/matrix-puppet-slack/issues/58)
- [x] Editing messages
- [ ] Redacting/deleting messages
- [ ] User Profiles
- [ ] /me emotes (https://github.com/matrix-hacks/matrix-puppet-slack/issues/17)
- [ ] Presence
- [x] @-mentions
- [ ] @channel/@here, as @room (Slack users' Matrix ghost users must have permission to @room notify in the Slack channel's Matrix ghost room; converting is not enough)
- [x] Third Party Lookup
- [x] Rooms
- [x] Users
- [x] Puppet a user's real Slack account.
- [ ] Rooms react to Slack updates