Broid Integrations is an open source project providing a suite of Activity Streams 2 libraries for unified interface among a vast number of communication platforms.
Connect your App to Multiple Messaging Channels with the W3C Open standard.
Broid Integrations provide a suite of libraries to convert all messaging platforms events to Activity Streams 2 schemas.
TL;DR
- All events are Observables (RxJS)
- All functions return a Promise (Bluebird)
- Highly modular to keep your focus on high level features
A quick example showing off listening for new messages on Facebook Messenger and Discord with Observables.
npm i --save @broid/messenger @broid/discord rxjs ramda
const Rx = require("rxjs/Rx");
const R = require("ramda");
const BroidDiscord = require("@broid/discord");
const BroidMessenger = require("@broid/messenger");
const clients = {
discord: new BroidDiscord({token: 'DISCORD_TOKEN'}),
messenger: new BroidMessenger({token: 'FACEBOOK_TOKEN', tokenSecret: 'FACEBOOK_SECRET'})
};
Rx.Observable.merge(...R.map(client => client.connect(), R.values(clients)))
.subscribe({
next: data => console.log(JSON.stringify(data, null, 2)),
error: err => console.error(`Something went wrong: ${err.message}`),
});
Rx.Observable.merge(...R.map(client => client.listen(), R.values(clients)))
.subscribe({
next: message => console.log(JSON.stringify(message, null, 2)),
error: err => console.error(`Something went wrong: ${err.message}`),
});
Check out Broid's quick Get Started guide to get a better feel of what Broid is capable of.
Broid Integrations support simple, media and rich messages (location, carroussel) and split into multiple libraries. This make Broid flexible and useful to use in your application.
Broid integrations supports Activity Streams 2.0 and uses broid-schemas package to validate input and output message.
Name | Status |
---|---|
broid-schemas |
If you have discovered a bug or have a feature suggestion, feel free to create an issue. If you create a integration, feel free to open a Pull Request!
You are also welcome to correct any spelling mistakes or any language issues.
If you want to discuss something or just need help, here is our Gitter room.
Make sure that you're read and understand the Code of Conduct.
To protect the interests of the Broid contributors, Broid, customers and end users we require contributors to sign a Contributors License Agreement (CLA) before we pull the changes into the main repository. Our CLA is simple and straightforward - it requires that the contributions you make to any Broid open source project are properly licensed and that you have the legal authority to make those changes. This helps us significantly reduce future legal risk for everyone involved. It's easy---no faxing or printing required!
You can digitally sign the CLA online. Please indicate your email address in your first pull request so that we can make sure that will locate your CLA. Once you've submitted it, you no longer need to send one for subsequent submissions.