# frozen_string_literal: true require 'nokogiri' require 'restforce' require 'date' require 'net/http' require 'faye' require 'fluent/plugin/input' module Fluent module Plugin class SforceInput < Input class SforceConnectionError < StandardError; end Fluent::Plugin.register_input('sforce', self) config_param :query, :string, default: 'SELECT id, Body, CreatedById FROM FeedItem' config_param :tag, :string, default: 'sforce' config_param :polling_interval, :integer, default: 60 config_param :topic, :string, default: nil config_param :username, :string config_param :password, :string config_param :version, :string, default: '43.0' config_param :login_endpoint, :string, default: 'login.salesforce.com' attr_accessor :client def configure(conf) super end def start super @client = generate_client if @topic == nil start_at = now loop do sleep(@polling_interval) end_at = now soql = build_query(start_at, end_at) begin log.info "query: #{soql}" records = exec_query(soql) records.each do |record| router.emit(@tag, Fluent::Engine.now, record) end start_at = end_at rescue Restforce::UnauthorizedError => e log.error e # retry login @client = generate_client end end else EM.run do log.info "suscribe: #{@topic}" subscribe @topic do |message| router.emit(@tag, Fluent::Engine.now, message) end end end rescue SforceConnectionError => e log.error e.message end def shutdown super end private def login uri = URI(login_endpoint) request = Net::HTTP::Post.new(uri.request_uri, {'Content-Type' =>'text/xml', 'SOAPAction' => "''"}) request.body = <