Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/unhappychoice/cycle-pusher
:recycle: Cycle.js driver for Pusher
https://github.com/unhappychoice/cycle-pusher
cyclejs library pusher typescript websocket wrapper
Last synced: 3 months ago
JSON representation
:recycle: Cycle.js driver for Pusher
- Host: GitHub
- URL: https://github.com/unhappychoice/cycle-pusher
- Owner: unhappychoice
- License: mit
- Created: 2017-10-24T12:14:24.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-10-09T08:05:50.000Z (4 months ago)
- Last Synced: 2024-10-11T13:37:13.056Z (4 months ago)
- Topics: cyclejs, library, pusher, typescript, websocket, wrapper
- Language: TypeScript
- Homepage:
- Size: 1.08 MB
- Stars: 6
- Watchers: 3
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# cycle-pusher
[data:image/s3,"s3://crabby-images/1bb6a/1bb6acbdd2893155f76fa35571689c93a8d1be5e" alt="npm version"](https://badge.fury.io/js/cycle-pusher)
[data:image/s3,"s3://crabby-images/99e62/99e623e01ef6ce85860ef70462e9257680397161" alt="Libraries.io dependency status for GitHub repo"](https://libraries.io/github/unhappychoice/cycle-pusher)
data:image/s3,"s3://crabby-images/f961c/f961c9d769d052ffb72ac9122a17778a00754fbf" alt="npm bundle size"
data:image/s3,"s3://crabby-images/ffbbf/ffbbf78484237e6ce2e04803f2b66be24226274d" alt="npm"
data:image/s3,"s3://crabby-images/d5371/d53711e5e1db28fb1a5380364d1cbcc91ed93850" alt="GitHub"cycle-pusher is pusher client for [cycle.js](https://cycle.js.org/)
### Types
```typescript
const makePusherDirver = (app_key: string, configuration: Config): Driver, PusherSource>interface PusherSource {
select(channelName: string, eventName: string): Stream;
}interface PayloadOutput {
channelName: string;
eventName: string;
data: any;
}interface PayloadInput {
channelName: string;
eventName: string;
data: any;
}
```### Usage
```typescript
function main(sources) {
const content$ = sources.pusher.select("channel1", "event1") // Receive messagesconst payload$ = Stream.of({ // Send messages
channelName: "channel1",
eventName: "client-event1",
data: { "key": "value" }
});return {
pusher: payload$
};
}const app_key = "";
const config = { // See pusher document
encrypted: true
};run(main, {
pusher: makePusherDirver(app_key, config)
});```
see example directory for real usage.
### License
see [LICENSE](./LICENSE)