lib/notifiable/sender.rb in notifiable-sender-0.6.0 vs lib/notifiable/sender.rb in notifiable-sender-0.7.0

- old
+ new

@@ -10,32 +10,42 @@ raise 'access_id cannot be nil' if !access_id || access_id.empty? @base_uri, @access_id, @secret_key, @logger = base_uri, access_id, secret_key, logger end - def send_notification_to_users(user_aliases, title: nil, message: nil, parameters: nil, content_available: nil, thread_id: nil) + def send_media_notification_to_users(user_aliases, media_url, title: nil, message: nil, parameters: {}, content_avaliable: nil, thread_id:nil) raise 'user_aliases should be an array' unless user_aliases.is_a? Array + raise 'media_url should not be blank' if media_url.nil? || media_url.empty? + parameters = {media_url: media_url}.merge(parameters) filters = [{property: "user_alias", predicate: "in", value: user_aliases}] - send_notification(title: title, message: message, parameters: parameters, content_available: content_available, filters: filters, thread_id: thread_id) + send_notification(title: title, message: message, parameters: parameters, content_available: content_avaliable, filters: filters, thread_id: thread_id, mutable_content: true) end + + def send_notification_to_users(user_aliases, title: nil, message: nil, parameters: nil, content_available: nil, thread_id: nil, mutable_content: nil) + raise 'user_aliases should be an array' unless user_aliases.is_a? Array + + filters = [{property: "user_alias", predicate: "in", value: user_aliases}] + send_notification(title: title, message: message, parameters: parameters, content_available: content_available, filters: filters, thread_id: thread_id, mutable_content: mutable_content) + end - def send_notification_to_user(user_alias, title: nil, message: nil, parameters: nil, content_available: nil, thread_id: nil) + def send_notification_to_user(user_alias, title: nil, message: nil, parameters: nil, content_available: nil, thread_id: nil, mutable_content: nil) filters = [{property: "user_alias", predicate: "eq", value: user_alias}] - send_notification(title: title, message: message, parameters: parameters, content_available: content_available, filters: filters, thread_id: thread_id) + send_notification(title: title, message: message, parameters: parameters, content_available: content_available, filters: filters, thread_id: thread_id, mutable_content: mutable_content) end # # Params: # - filters: An array of hashes to filter notifications, e.g. [{property: "alert_level", predicate: "lt", value: 3}] - def send_notification(title: nil, message: nil, parameters: nil, filters: nil, content_available: nil, thread_id: nil) + def send_notification(title: nil, message: nil, parameters: nil, filters: nil, content_available: nil, thread_id: nil, mutable_content: nil) body = {} body[:title] = title unless title.nil? body[:message] = message unless message.nil? body[:parameters] = parameters.to_json unless parameters.nil? body[:filters] = filters.to_json unless filters.nil? body[:content_available] = content_available unless content_available.nil? body[:thread_id] = thread_id unless thread_id.nil? + body[:mutable_content] = mutable_content unless mutable_content.nil? headers = {} headers[:authorization] = @access_id unless @secret_key @request = RestClient::Request.new url: "#{@base_uri}/api/v1/notifications", payload: {notification: body}, method: :post, headers: headers @request = ApiAuth.sign!(@request, @access_id, @secret_key) if @secret_key