Class: Dependabot::FileFetchers::Base
- Inherits:
-
Object
- Object
- Dependabot::FileFetchers::Base
- Defined in:
- lib/dependabot/file_fetchers/base.rb
Direct Known Subclasses
Constant Summary collapse
- CLIENT_NOT_FOUND_ERRORS =
[ Octokit::NotFound, Gitlab::Error::NotFound, Dependabot::Clients::Azure::NotFound, Dependabot::Clients::Bitbucket::NotFound, Dependabot::Clients::CodeCommit::NotFound ].freeze
Instance Attribute Summary collapse
-
#credentials ⇒ Object
readonly
Returns the value of attribute credentials.
-
#options ⇒ Object
readonly
Returns the value of attribute options.
-
#repo_contents_path ⇒ Object
readonly
Returns the value of attribute repo_contents_path.
-
#source ⇒ Object
readonly
Returns the value of attribute source.
Class Method Summary collapse
Instance Method Summary collapse
-
#clone_repo_contents ⇒ Object
Returns the path to the cloned repo.
- #commit ⇒ Object
- #directory ⇒ Object
- #files ⇒ Object
-
#initialize(source:, credentials:, repo_contents_path: nil, options: {}) ⇒ Base
constructor
Creates a new FileFetcher for retrieving ‘DependencyFile`s.
- #repo ⇒ Object
- #target_branch ⇒ Object
Constructor Details
#initialize(source:, credentials:, repo_contents_path: nil, options: {}) ⇒ Base
Creates a new FileFetcher for retrieving ‘DependencyFile`s.
Files are typically grabbed individually via the source’s API. repo_contents_path is an optional empty directory that will be used to clone the entire source repository on first read.
If provided, file data will be loaded from the clone. Submodules and directory listings are not currently supported by repo_contents_path and still use an API trip.
options supports custom feature enablement
48 49 50 51 52 53 54 |
# File 'lib/dependabot/file_fetchers/base.rb', line 48 def initialize(source:, credentials:, repo_contents_path: nil, options: {}) @source = source @credentials = credentials @repo_contents_path = repo_contents_path @linked_paths = {} @options = end |
Instance Attribute Details
#credentials ⇒ Object (readonly)
Returns the value of attribute credentials.
19 20 21 |
# File 'lib/dependabot/file_fetchers/base.rb', line 19 def credentials @credentials end |
#options ⇒ Object (readonly)
Returns the value of attribute options.
19 20 21 |
# File 'lib/dependabot/file_fetchers/base.rb', line 19 def @options end |
#repo_contents_path ⇒ Object (readonly)
Returns the value of attribute repo_contents_path.
19 20 21 |
# File 'lib/dependabot/file_fetchers/base.rb', line 19 def repo_contents_path @repo_contents_path end |
#source ⇒ Object (readonly)
Returns the value of attribute source.
19 20 21 |
# File 'lib/dependabot/file_fetchers/base.rb', line 19 def source @source end |
Class Method Details
.required_files_in?(_filename_array) ⇒ Boolean
29 30 31 |
# File 'lib/dependabot/file_fetchers/base.rb', line 29 def self.required_files_in?(_filename_array) raise NotImplementedError end |
.required_files_message ⇒ Object
33 34 35 |
# File 'lib/dependabot/file_fetchers/base.rb', line 33 def self. raise NotImplementedError end |
Instance Method Details
#clone_repo_contents ⇒ Object
Returns the path to the cloned repo
86 87 88 89 90 91 92 93 94 95 |
# File 'lib/dependabot/file_fetchers/base.rb', line 86 def clone_repo_contents @clone_repo_contents ||= _clone_repo_contents(target_directory: repo_contents_path) rescue Dependabot::SharedHelpers::HelperSubprocessFailed => e if e..include?("fatal: Remote branch #{target_branch} not found in upstream origin") raise Dependabot::BranchNotFound, target_branch end raise Dependabot::RepoNotFound, source end |
#commit ⇒ Object
72 73 74 75 76 77 78 79 80 81 82 83 |
# File 'lib/dependabot/file_fetchers/base.rb', line 72 def commit return cloned_commit if cloned_commit return source.commit if source.commit branch = target_branch || default_branch_for_repo @commit ||= client_for_provider.fetch_commit(repo, branch) rescue *CLIENT_NOT_FOUND_ERRORS raise Dependabot::BranchNotFound, branch rescue Octokit::Conflict => e raise unless e..include?("Repository is empty") end |
#directory ⇒ Object
60 61 62 |
# File 'lib/dependabot/file_fetchers/base.rb', line 60 def directory Pathname.new(source.directory || "/").cleanpath.to_path end |
#files ⇒ Object
68 69 70 |
# File 'lib/dependabot/file_fetchers/base.rb', line 68 def files @files ||= fetch_files end |
#repo ⇒ Object
56 57 58 |
# File 'lib/dependabot/file_fetchers/base.rb', line 56 def repo source.repo end |
#target_branch ⇒ Object
64 65 66 |
# File 'lib/dependabot/file_fetchers/base.rb', line 64 def target_branch source.branch end |