# PubNub Ruby SDK [![Codacy Badge](https://api.codacy.com/project/badge/Grade/b744287bb0324e2883f95525b12cf19f)](https://www.codacy.com/app/blazeroot/ruby?utm_source=github.com&utm_medium=referral&utm_content=pubnub/ruby&utm_campaign=badger) [![Codacy Badge](https://api.codacy.com/project/badge/Coverage/b744287bb0324e2883f95525b12cf19f)](https://www.codacy.com/app/blazeroot/ruby?utm_source=github.com&utm_medium=referral&utm_content=pubnub/ruby&utm_campaign=Badge_Coverage) [![Build Status](https://travis-ci.org/pubnub/ruby.svg?branch=master)](https://travis-ci.org/pubnub/ruby) This is the official PubNub Ruby SDK repository. PubNub takes care of the infrastructure and APIs needed for the realtime communication layer of your application. Work on your app's logic and let PubNub handle sending and receiving data across the world in less than 100ms. ## Get keys You will need the publish and subscribe keys to authenticate your app. Get your keys from the [Admin Portal](https://dashboard.pubnub.com/). ## Configure PubNub 1. Integrate PubNub into your project using RubyGems: ```bash gem install pubnub ``` 1. Create a new `App.rb` file and add the following code. ```ruby require 'pubnub' pubnub = Pubnub.new( subscribe_key: :mySubscribeKey, publish_key: :myPublishKey, uuid: :myUniqueUUID ) ``` This is the minimum configuration you need to send and receive messages with PubNub. ## Add event listeners ```ruby callback = Pubnub::SubscribeCallback.new( message: ->(envelope) { puts "MESSAGE: #{puts envelope.result[:data][:message]['msg']}" }, presence: ->(envelope) { puts "PRESENCE: #{envelope.result[:data]}" } ) pubnub.add_listener(callback: callback) ``` ## Publish and subscribe ```ruby pubnub.subscribe( channels: ['my_channel'], with_presence: true ) pubnub.publish( channel: 'my_channel', message: { text: 'Hello world' } ) do |envelope| puts envelope.status end ``` ## Documentation [API reference for Ruby](https://www.pubnub.com/docs/ruby/pubnub-ruby-sdk) ## Support If you **need help** or have a **general question**, contact .