Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/peburrows/kane
Google Pub/Sub client for Elixir
https://github.com/peburrows/kane
elixir gcp google-cloud-platform google-cloud-pubsub pubsub
Last synced: 2 months ago
JSON representation
Google Pub/Sub client for Elixir
- Host: GitHub
- URL: https://github.com/peburrows/kane
- Owner: peburrows
- License: mit
- Created: 2016-01-22T05:04:37.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-08-25T23:43:10.000Z (over 1 year ago)
- Last Synced: 2024-04-13T22:00:11.033Z (9 months ago)
- Topics: elixir, gcp, google-cloud-platform, google-cloud-pubsub, pubsub
- Language: Elixir
- Homepage: http://hexdocs.pm/kane
- Size: 111 KB
- Stars: 104
- Watchers: 2
- Forks: 44
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - A [Google Cloud Pub/Sub](https://cloud.google.com/pubsub/overview) client. (Third Party APIs)
- fucking-awesome-elixir - kane - A [Google Cloud Pub/Sub](https://cloud.google.com/pubsub/overview) client. (Third Party APIs)
- awesome-elixir - kane - A [Google Cloud Pub/Sub](https://cloud.google.com/pubsub/overview) client. (Third Party APIs)
README
[![Build Status](https://travis-ci.org/peburrows/kane.svg?branch=master)](https://travis-ci.org/peburrows/kane)
# Kane
Kane. Citizen Kane. Charles Foster Kane, to be exact, Publisher extraordinaire. Rosebud.
Kane is for publishing and subscribing to topics using Google Cloud Pub/Sub.
## Installation
1. Add Kane to your list of dependencies in `mix.exs`:
```elixir
def deps do
[{:kane, "~> 0.9.0"}]
end
```2. Configure [Goth](https://github.com/peburrows/goth) (Kane's underlying token storage and retrieval library) with your Google JSON credentials.
## Usage
Pull, process and acknowledge messages via a pre-existing subscription:
```elixir
{:ok, token} = Goth.fetch(MyApp.Goth)kane = %Kane{
project_id: my_app_gcp_credentials["project_id"],
token: token
}subscription = %Kane.Subscription{
name: "my-sub",
topic: %Kane.Topic{
name: "my-topic"
}
}{:ok, messages} = Kane.Subscription.pull(kane, subscription)
Enum.each messages, fn(mess)->
process_message(mess)
end# acknowledge message receipt in bulk
Kane.Subscription.ack(kane, subscription, messages)
```Send message via pre-existing subscription:
```elixir
topic = %Kane.Topic{name: "my-topic"}
message = %Kane.Message{data: %{"hello": "world"}, attributes: %{"random" => "attr"}}result = Kane.Message.publish(kane, message, topic)
case result do
{:ok, _return} -> IO.puts("It worked!")
{:error, _reason} -> IO.puts("Should we try again?")
end
```Hints:
- Attributes have to be Strings (https://cloud.google.com/pubsub/docs/reference/rest/v1/PubsubMessage)
- We base64-encode the message by default (only mandatory when using json - https://cloud.google.com/pubsub/publisher)For more details, see the [documentation](http://hexdocs.pm/kane).