Sha256: c6ae0f4aa858920926db6ee30cda2774d7ab1a53d558a692dbd82437b5e2507e

Contents?: true

Size: 1.9 KB

Versions: 1

Compression:

Stored size: 1.9 KB

Contents

# frozen_string_literal: true

require 'tempfile'
require_relative 'gemfile_health_score'

module Polariscope
  module Scanner
    class CodebaseHealthScore
      def initialize(gemfile_content:, gemfile_lock_content:, bundler_audit_config_content:)
        @gemfile_content = gemfile_content
        @gemfile_lock_content = gemfile_lock_content
        @bundler_audit_config_content = bundler_audit_config_content
      end

      def health_score
        return nil if blank?(gemfile_content) || blank?(gemfile_lock_content)

        begin
          GemfileHealthScore.new(gemfile_path: gemfile_file.path, gemfile_lock_content: gemfile_lock_content,
                                 bundler_audit_config_path: bundler_audit_config_file.path,
                                 update_audit_database: update_audit_database?).health_score
        ensure
          gemfile_file.unlink
          bundler_audit_config_file.unlink
        end
      end

      private

      attr_reader :gemfile_content
      attr_reader :gemfile_lock_content
      attr_reader :bundler_audit_config_content

      def gemfile_file
        @gemfile_file ||= begin
          file = Tempfile.new('Gemfile')
          file.write(gemfile_content.gsub("gemspec\n", '').gsub(/^ruby.*$\R/, ''))
          file.close
          file
        end
      end

      def bundler_audit_config_file
        @bundler_audit_config_file ||= begin
          file = Tempfile.new('.bundler-audit.yml')
          file.write(bundler_audit_config_content)
          file.close
          file
        end
      end

      def blank?(value)
        value.nil? || value == ''
      end

      def update_audit_database?
        audit_db_missing? || audit_db_stale?
      end

      def audit_db_missing?
        !Bundler::Audit::Database.exists?
      end

      def audit_db_stale?
        ((Time.now - Bundler::Audit::Database.new.last_updated_at) / 86_400) > 7
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
polariscope-0.3.0 lib/polariscope/scanner/codebase_health_score.rb