Sha256: 483cc6b556562a0ca385e179048aac25b974d35bdcdfd10e08b6fa8a5836377d

Contents?: true

Size: 1.96 KB

Versions: 21

Compression:

Stored size: 1.96 KB

Contents

require 'flydata/fluent-plugins/mysql/alter_table_query_handler'
require 'flydata/fluent-plugins/mysql/truncate_table_query_handler'
require 'flydata/fluent-plugins/mysql/drop_database_query_handler'

module Mysql
  class BinlogQueryDispatcher
    def initialize
      @handlers = []
    end

    def dispatch(record)
      normalize_query(record["query"]) do |query|
        @handlers.each do |handler|
          if (handler.pattern.match(query))
            handler.process(record.merge({"normalized_query" => query}))
            break
          end
        end
      end
    end

    private

    PLACEMENT = '{}'
    def normalize_query(queries)
      q = queries.dup
      strings = []
      # \/\*.*?\*\/        /* */ style comment
      # `.*?`              `resource_name`
      # '(?:\\.|.)*?'      'string'
      # "(?:\\.|.)*?"      "string"
      # --\s+.*?(?:\n|$)   -- style comment
      # #\s+.*?(?:\n|$)    # style comment
      q.gsub!(/(\/\*.*?\*\/|`.*?`|'(?:\\.|.)*?'|"(?:\\.|.)*?"|--\s+.*?(?:\n|$)|#.*?(?:\n|$))/m) do |m|
        comment_or_quoted = $&
        if comment_or_quoted.start_with?("/*") || comment_or_quoted.start_with?("--") ||
           comment_or_quoted.start_with?("#")
          # comment. replace with a space
          ' '
        else
          # string.  save the original and replace with an temporary placement
          strings << comment_or_quoted
          PLACEMENT
        end
      end
      q = q.gsub(/\s+/, ' ') # replace multiple spaces with a space
      q.split(';').each do |query|
        query = query.lstrip
        query.gsub!(PLACEMENT) do |m|
          strings.shift
        end
        yield(query + ";") if block_given? && !query.empty?
      end
    end
  end

  class FlydataBinlogQueryDispatcher < BinlogQueryDispatcher
    def initialize(context)
      @handlers = [
        AlterTableQueryHandler.new(context),
        TruncateTableQueryHandler.new(context),
        DropDatabaseQueryHandler.new(context),
      ]
    end
  end
end

Version data entries

21 entries across 21 versions & 1 rubygems

Version Path
flydata-0.6.11 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.10 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.9 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.8 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.7 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.6 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.5 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.4 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.3 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.2 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.1 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.6.0 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.21 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.20 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.17 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.16 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.15 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.14 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.13 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb
flydata-0.5.12 lib/flydata/fluent-plugins/mysql/binlog_query_dispatcher.rb