ruby-analysis/delfos

View on GitHub
lib/delfos/neo4j.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

require_relative "neo4j/query_execution/sync"
require_relative "neo4j/query_execution/batch/retryable"
require_relative "neo4j/schema"
require_relative "neo4j/distance/update"
require_relative "neo4j/offline"

module Delfos
  module Neo4j
    extend self

    def execute_sync(query, params = {})
      QueryExecution::Sync.new(query, params).perform
    end

    def execute(query, params = {})
      QueryExecution::Batch::Retryable.execute!(query, params: params, size: Delfos.batch_size)
    end

    def flush!
      QueryExecution::Batch::Retryable.flush!
    end

    def reset!
      Delfos::Neo4j::QueryExecution::Batch::Retryable.reset!
    end

    def ensure_schema!
      Schema.ensure_constraints!(
        "Class"     => "name",
        "CallStack" => "number",
      )
    end

    def import_offline_queries(filename)
      Offline.import_queries(filename)
    end

    def update_distance!
      Distance::Update.new.perform
    end

    def config
      host     ||= ENV["NEO4J_HOST"]     || "http://localhost"
      port     ||= ENV["NEO4J_PORT"]     || "8476"
      username ||= ENV["NEO4J_USERNAME"] || "neo4j"
      password ||= ENV["NEO4J_PASSWORD"] || "password"

      Neo4jConfig.new(host, port, username, password)
    end

    Neo4jConfig = Struct.new(:host, :port, :username, :password) do
      def url
        "#{host}:#{port}"
      end

      def uri_for(path)
        URI.parse("#{url}#{path}")
      end

      def to_s
        "  host: #{host}\n  port: #{port}\n  username: #{username}\n  password: #{password}"
      end
    end
  end
end