Sha256: 66f1a251afda8722c7f864690dc1cc54225227cbc228cd141c86db5e580ab49a
Contents?: true
Size: 1.89 KB
Versions: 6
Compression:
Stored size: 1.89 KB
Contents
module Pubnub class Grant include Pubnub::Event include Pubnub::SingleEvent include Pubnub::Formatter include Pubnub::Validator include Pubnub::PAM def initialize(options, app) super @event = 'grant' @allow_multiple_channels = false @timestamp = current_time @write = options[:write] @read = options[:read] @ttl = options[:ttl] || Pubnub::Configuration::DEFAULT_TTL end def validate! super raise ArgumentError.new(:object => self, :message => 'publish_key is required by Grant') unless @publish_key raise ArgumentError.new(:object => self, :message => 'Parameter secret_key is required by Grant') if !@secret_key || @secret_key == 0 raise ArgumentError.new(:object => self, :message => 'write parameter accept only one of: 1, "1", 0, "0", true, false values') unless [nil, 1, '1', 0, '0', true, false].include?(@write) raise ArgumentError.new(:object => self, :message => 'read parameter accept only: 1, "1", 0, "0", true, false values') unless [nil, 1, '1', 0, '0', true, false].include?(@read) raise ArgumentError.new(:object => self, :message => 'ttl parameter is too big, max value is: 525600') unless @ttl.to_i <= 525600 || @ttl.nil? raise ArgumentError.new(:object => self, :message => 'ttl parameter can\'t be negative') unless @ttl.to_i >= 0 || @ttl.nil? end private def parameters(app, signature = false) write = [0, '0', false].include?(@write) ? 0 : 1 read = [0, '0', false].include?(@read) ? 0 : 1 { :timestamp => @timestamp, :w => write, :r => read, :ttl => @ttl }.merge(super(app, signature)) end def path(app) '/' + [ 'v1', 'auth', 'grant', 'sub-key', @subscribe_key ].join('/') end end end
Version data entries
6 entries across 6 versions & 1 rubygems