Sha256: f215087edaf7b647ef83c4d7fc49a36f62fc26e9b589625170161b64619f357a

Contents?: true

Size: 1.91 KB

Versions: 5

Compression:

Stored size: 1.91 KB

Contents

# frozen_string_literal: true

require 'base64'
require 'tempfile'
require 'zlib'

module Octokit
  class Client
    # Methods for the code scanning alerts API
    #
    # @see https://docs.github.com/rest/code-scanning
    module CodeScanning
      # Uploads SARIF data containing the results of a code scanning analysis
      #
      # @param repo [Integer, String, Repository, Hash] A GitHub repository
      # @param file [String] Path to the SARIF file to upload
      # @param sha [String] The SHA of the commit to which the analysis you are uploading relates
      # @param ref [String] The full Git reference, formatted as `refs/heads/<branch name>`, `refs/pull/<number>/merge`, or `refs/pull/<number>/head`
      #
      # @return [Sawyer::Resource] SARIF upload information
      # @see https://docs.github.com/rest/code-scanning#upload-an-analysis-as-sarif-data
      def upload_sarif_data(repo, file, sha, ref, options = {})
        options[:sarif] = compress_sarif_data(file)
        options[:commit_sha] = sha
        options[:ref] = ref

        post "#{Repository.path repo}/code-scanning/sarifs", options
      end

      # Gets information about a SARIF upload
      #
      # @param repo [Integer, String, Repository, Hash] A GitHub repository
      # @param sarif_id [String] The SARIF ID obtained after uploading
      #
      # @return [Sawyer::Resource] SARIF upload information
      # @see https://docs.github.com/rest/code-scanning#get-information-about-a-sarif-upload
      def get_sarif_upload_information(repo, sarif_id, options = {})
        get "#{Repository.path repo}/code-scanning/sarifs/#{sarif_id}", options
      end

      private

      def compress_sarif_data(file)
        Tempfile.create('sarif.gz') do |tempfile|
          Zlib::GzipWriter.open(tempfile) do |gz_file|
            gz_file.write File.binread(file)
          end
          Base64.strict_encode64(tempfile.read)
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
octokit-8.1.0 lib/octokit/client/code_scanning.rb
octokit-8.0.0 lib/octokit/client/code_scanning.rb
octokit-7.2.0 lib/octokit/client/code_scanning.rb
octokit-7.1.0 lib/octokit/client/code_scanning.rb
octokit-7.0.0 lib/octokit/client/code_scanning.rb