Popularity
7.1
Stable
Activity
0.0
Stable
104
2
47
Monthly Downloads: 9,222
Programming language: Elixir
License: MIT License
Tags:
Third Party APIs
Latest version: v0.8.1
kane alternatives and similar packages
Based on the "Third Party APIs" category.
Alternatively, view kane alternatives based on common mentions on social networks and blogs.
-
Semaphore
Semaphore is an open source CI/CD platform. Self-host Semaphore on your own servers or on a cloud provider. -
MongoosePush
MongoosePush is a simple Elixir RESTful service allowing to send push notification via FCM and/or APNS. -
cashier
Cashier is an Elixir library that aims to be an easy to use payment gateway, whilst offering the fault tolerance and scalability benefits of being built on top of Erlang/OTP
CodeRabbit: AI Code Reviews for Developers
Revolutionize your code reviews with AI. CodeRabbit offers PR summaries, code walkthroughs, 1-click suggestions, and AST-based analysis. Boost productivity and code quality across all major languages with each PR.
Promo
coderabbit.ai

Do you think we are missing an alternative of kane or a related project?
Popular Comparisons
README
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
- Add Kane to your list of dependencies in
mix.exs
:
def deps do
[{:kane, "~> 0.7.0"}]
end
- Configure Goth (Kane's underlying token storage and retrieval library) with your Google JSON credentials:
config :goth,
json: "path/to/google/json/creds.json" |> File.read!
- Ensure Kane is started before your application:
def application do
[applications: [:kane]]
end
Usage
Pull, process and acknowledge messages via a pre-existing subscription:
subscription = %Kane.Subscription{
name: "my-sub",
topic: %Kane.Topic{
name: "my-topic"
}
}
{:ok, messages} = Kane.Subscription.pull(subscription)
Enum.each messages, fn(mess)->
process_message(mess)
end
# acknowledge message receipt in bulk
Kane.Subscription.ack(subscription, messages)
Send message via pre-existing subscription:
topic = %Kane.Topic{name: "my-topic"}
message = %Kane.Message{data: %{"hello": "world"}, attributes: %{"random" => "attr"}}
result = Kane.Message.publish(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.