dependabot-core 0.76.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (321) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +6408 -0
  3. data/LICENSE +37 -0
  4. data/README.md +115 -0
  5. data/helpers/elixir/bin/check_update.exs +92 -0
  6. data/helpers/elixir/bin/do_update.exs +39 -0
  7. data/helpers/elixir/bin/parse_deps.exs +103 -0
  8. data/helpers/elixir/bin/run.exs +76 -0
  9. data/helpers/elixir/mix.exs +21 -0
  10. data/helpers/elixir/mix.lock +3 -0
  11. data/helpers/go/Makefile +9 -0
  12. data/helpers/go/go.mod +9 -0
  13. data/helpers/go/go.sum +5 -0
  14. data/helpers/go/importresolver/main.go +34 -0
  15. data/helpers/go/main.go +77 -0
  16. data/helpers/go/updatechecker/main.go +107 -0
  17. data/helpers/go/updater/go.mod +3 -0
  18. data/helpers/go/updater/go.sum +2 -0
  19. data/helpers/go/updater/helpers.go +57 -0
  20. data/helpers/go/updater/main.go +48 -0
  21. data/helpers/npm/.agignore +1 -0
  22. data/helpers/npm/.envrc +2 -0
  23. data/helpers/npm/.eslintrc +14 -0
  24. data/helpers/npm/.nvimrc +7 -0
  25. data/helpers/npm/bin/run.js +34 -0
  26. data/helpers/npm/lib/helpers.js +25 -0
  27. data/helpers/npm/lib/peer-dependency-checker.js +102 -0
  28. data/helpers/npm/lib/subdependency-updater.js +48 -0
  29. data/helpers/npm/lib/updater.js +95 -0
  30. data/helpers/npm/package.json +17 -0
  31. data/helpers/npm/test/fixtures/npm-left-pad.json +1 -0
  32. data/helpers/npm/test/fixtures/updater/original/package-lock.json +16 -0
  33. data/helpers/npm/test/fixtures/updater/original/package.json +9 -0
  34. data/helpers/npm/test/fixtures/updater/updated/package-lock.json +16 -0
  35. data/helpers/npm/test/helpers.js +7 -0
  36. data/helpers/npm/test/updater.test.js +50 -0
  37. data/helpers/npm/yarn.lock +6120 -0
  38. data/helpers/php/.php_cs +34 -0
  39. data/helpers/php/bin/run.php +57 -0
  40. data/helpers/php/composer.json +14 -0
  41. data/helpers/php/composer.lock +1521 -0
  42. data/helpers/php/composer.phar +0 -0
  43. data/helpers/php/setup.sh +4 -0
  44. data/helpers/php/src/DependabotInstallationManager.php +61 -0
  45. data/helpers/php/src/DependabotPluginManager.php +23 -0
  46. data/helpers/php/src/ExceptionIO.php +25 -0
  47. data/helpers/php/src/Hasher.php +21 -0
  48. data/helpers/php/src/UpdateChecker.php +123 -0
  49. data/helpers/php/src/Updater.php +97 -0
  50. data/helpers/python/lib/__init__.py +0 -0
  51. data/helpers/python/lib/hasher.py +23 -0
  52. data/helpers/python/lib/parser.py +130 -0
  53. data/helpers/python/requirements.txt +9 -0
  54. data/helpers/python/run.py +18 -0
  55. data/helpers/test/run.rb +15 -0
  56. data/helpers/utils/git-credential-store-immutable +10 -0
  57. data/helpers/yarn/.agignore +1 -0
  58. data/helpers/yarn/.envrc +2 -0
  59. data/helpers/yarn/.eslintrc +14 -0
  60. data/helpers/yarn/.nvimrc +7 -0
  61. data/helpers/yarn/bin/run.js +36 -0
  62. data/helpers/yarn/lib/fix-duplicates.js +53 -0
  63. data/helpers/yarn/lib/helpers.js +5 -0
  64. data/helpers/yarn/lib/lockfile-parser.js +21 -0
  65. data/helpers/yarn/lib/peer-dependency-checker.js +130 -0
  66. data/helpers/yarn/lib/replace-lockfile-declaration.js +45 -0
  67. data/helpers/yarn/lib/subdependency-updater.js +69 -0
  68. data/helpers/yarn/lib/updater.js +254 -0
  69. data/helpers/yarn/package.json +17 -0
  70. data/helpers/yarn/test/fixtures/updater/original/package.json +6 -0
  71. data/helpers/yarn/test/fixtures/updater/original/yarn.lock +11 -0
  72. data/helpers/yarn/test/fixtures/updater/updated/yarn.lock +12 -0
  73. data/helpers/yarn/test/fixtures/updater/with-version-comments/package.json +5 -0
  74. data/helpers/yarn/test/fixtures/updater/with-version-comments/yarn.lock +13 -0
  75. data/helpers/yarn/test/fixtures/yarnpkg-is-positive.json +1 -0
  76. data/helpers/yarn/test/fixtures/yarnpkg-left-pad.json +1 -0
  77. data/helpers/yarn/test/helpers.js +7 -0
  78. data/helpers/yarn/test/updater.test.js +93 -0
  79. data/helpers/yarn/yarn.lock +4912 -0
  80. data/lib/bundler_definition_bundler_version_patch.rb +15 -0
  81. data/lib/bundler_definition_ruby_version_patch.rb +14 -0
  82. data/lib/bundler_git_source_patch.rb +27 -0
  83. data/lib/dependabot.rb +4 -0
  84. data/lib/dependabot/clients/bitbucket.rb +101 -0
  85. data/lib/dependabot/clients/github_with_retries.rb +117 -0
  86. data/lib/dependabot/clients/gitlab.rb +72 -0
  87. data/lib/dependabot/dependency.rb +118 -0
  88. data/lib/dependabot/dependency_file.rb +54 -0
  89. data/lib/dependabot/errors.rb +179 -0
  90. data/lib/dependabot/file_fetchers.rb +48 -0
  91. data/lib/dependabot/file_fetchers/README.md +65 -0
  92. data/lib/dependabot/file_fetchers/base.rb +302 -0
  93. data/lib/dependabot/file_fetchers/docker/docker.rb +40 -0
  94. data/lib/dependabot/file_fetchers/dotnet/nuget.rb +215 -0
  95. data/lib/dependabot/file_fetchers/dotnet/nuget/import_paths_finder.rb +51 -0
  96. data/lib/dependabot/file_fetchers/dotnet/nuget/sln_project_paths_finder.rb +55 -0
  97. data/lib/dependabot/file_fetchers/elixir/hex.rb +78 -0
  98. data/lib/dependabot/file_fetchers/elm/elm_package.rb +52 -0
  99. data/lib/dependabot/file_fetchers/git/submodules.rb +73 -0
  100. data/lib/dependabot/file_fetchers/go/dep.rb +69 -0
  101. data/lib/dependabot/file_fetchers/go/modules.rb +64 -0
  102. data/lib/dependabot/file_fetchers/java/gradle.rb +56 -0
  103. data/lib/dependabot/file_fetchers/java/gradle/settings_file_parser.rb +66 -0
  104. data/lib/dependabot/file_fetchers/java/maven.rb +127 -0
  105. data/lib/dependabot/file_fetchers/java_script/npm_and_yarn.rb +330 -0
  106. data/lib/dependabot/file_fetchers/java_script/npm_and_yarn/path_dependency_builder.rb +107 -0
  107. data/lib/dependabot/file_fetchers/php/composer.rb +131 -0
  108. data/lib/dependabot/file_fetchers/python/pip.rb +305 -0
  109. data/lib/dependabot/file_fetchers/ruby/bundler.rb +185 -0
  110. data/lib/dependabot/file_fetchers/ruby/bundler/child_gemfile_finder.rb +70 -0
  111. data/lib/dependabot/file_fetchers/ruby/bundler/path_gemspec_finder.rb +114 -0
  112. data/lib/dependabot/file_fetchers/ruby/bundler/require_relative_finder.rb +67 -0
  113. data/lib/dependabot/file_fetchers/rust/cargo.rb +240 -0
  114. data/lib/dependabot/file_parsers.rb +48 -0
  115. data/lib/dependabot/file_parsers/README.md +45 -0
  116. data/lib/dependabot/file_parsers/base.rb +31 -0
  117. data/lib/dependabot/file_parsers/base/dependency_set.rb +77 -0
  118. data/lib/dependabot/file_parsers/docker/docker.rb +164 -0
  119. data/lib/dependabot/file_parsers/dotnet/nuget.rb +85 -0
  120. data/lib/dependabot/file_parsers/dotnet/nuget/packages_config_parser.rb +65 -0
  121. data/lib/dependabot/file_parsers/dotnet/nuget/project_file_parser.rb +156 -0
  122. data/lib/dependabot/file_parsers/dotnet/nuget/property_value_finder.rb +131 -0
  123. data/lib/dependabot/file_parsers/elixir/hex.rb +134 -0
  124. data/lib/dependabot/file_parsers/elm/elm_package.rb +136 -0
  125. data/lib/dependabot/file_parsers/git/submodules.rb +69 -0
  126. data/lib/dependabot/file_parsers/go/dep.rb +163 -0
  127. data/lib/dependabot/file_parsers/go/modules.rb +34 -0
  128. data/lib/dependabot/file_parsers/go/modules/go_mod_parser.rb +134 -0
  129. data/lib/dependabot/file_parsers/java/gradle.rb +236 -0
  130. data/lib/dependabot/file_parsers/java/gradle/property_value_finder.rb +90 -0
  131. data/lib/dependabot/file_parsers/java/gradle/repositories_finder.rb +145 -0
  132. data/lib/dependabot/file_parsers/java/maven.rb +252 -0
  133. data/lib/dependabot/file_parsers/java/maven/property_value_finder.rb +166 -0
  134. data/lib/dependabot/file_parsers/java/maven/repositories_finder.rb +188 -0
  135. data/lib/dependabot/file_parsers/java_script/npm_and_yarn.rb +394 -0
  136. data/lib/dependabot/file_parsers/php/composer.rb +177 -0
  137. data/lib/dependabot/file_parsers/python/pip.rb +223 -0
  138. data/lib/dependabot/file_parsers/python/pip/pipfile_files_parser.rb +154 -0
  139. data/lib/dependabot/file_parsers/python/pip/poetry_files_parser.rb +141 -0
  140. data/lib/dependabot/file_parsers/python/pip/setup_file_parser.rb +160 -0
  141. data/lib/dependabot/file_parsers/ruby/bundler.rb +295 -0
  142. data/lib/dependabot/file_parsers/ruby/bundler/file_preparer.rb +85 -0
  143. data/lib/dependabot/file_parsers/ruby/bundler/gemfile_checker.rb +48 -0
  144. data/lib/dependabot/file_parsers/rust/cargo.rb +213 -0
  145. data/lib/dependabot/file_updaters.rb +48 -0
  146. data/lib/dependabot/file_updaters/README.md +58 -0
  147. data/lib/dependabot/file_updaters/base.rb +52 -0
  148. data/lib/dependabot/file_updaters/docker/docker.rb +133 -0
  149. data/lib/dependabot/file_updaters/dotnet/nuget.rb +151 -0
  150. data/lib/dependabot/file_updaters/dotnet/nuget/packages_config_declaration_finder.rb +69 -0
  151. data/lib/dependabot/file_updaters/dotnet/nuget/project_file_declaration_finder.rb +78 -0
  152. data/lib/dependabot/file_updaters/dotnet/nuget/property_value_updater.rb +64 -0
  153. data/lib/dependabot/file_updaters/elixir/hex.rb +71 -0
  154. data/lib/dependabot/file_updaters/elixir/hex/lockfile_updater.rb +147 -0
  155. data/lib/dependabot/file_updaters/elixir/hex/mixfile_git_pin_updater.rb +53 -0
  156. data/lib/dependabot/file_updaters/elixir/hex/mixfile_requirement_updater.rb +74 -0
  157. data/lib/dependabot/file_updaters/elixir/hex/mixfile_sanitizer.rb +28 -0
  158. data/lib/dependabot/file_updaters/elixir/hex/mixfile_updater.rb +98 -0
  159. data/lib/dependabot/file_updaters/elm/elm_package.rb +79 -0
  160. data/lib/dependabot/file_updaters/elm/elm_package/elm_json_updater.rb +69 -0
  161. data/lib/dependabot/file_updaters/elm/elm_package/elm_package_updater.rb +69 -0
  162. data/lib/dependabot/file_updaters/git/submodules.rb +38 -0
  163. data/lib/dependabot/file_updaters/go/dep.rb +77 -0
  164. data/lib/dependabot/file_updaters/go/dep/lockfile_updater.rb +219 -0
  165. data/lib/dependabot/file_updaters/go/dep/manifest_updater.rb +155 -0
  166. data/lib/dependabot/file_updaters/go/modules.rb +71 -0
  167. data/lib/dependabot/file_updaters/go/modules/go_mod_updater.rb +81 -0
  168. data/lib/dependabot/file_updaters/java/gradle.rb +176 -0
  169. data/lib/dependabot/file_updaters/java/gradle/dependency_set_updater.rb +66 -0
  170. data/lib/dependabot/file_updaters/java/gradle/property_value_updater.rb +58 -0
  171. data/lib/dependabot/file_updaters/java/maven.rb +155 -0
  172. data/lib/dependabot/file_updaters/java/maven/declaration_finder.rb +132 -0
  173. data/lib/dependabot/file_updaters/java/maven/property_value_updater.rb +61 -0
  174. data/lib/dependabot/file_updaters/java_script/npm_and_yarn.rb +159 -0
  175. data/lib/dependabot/file_updaters/java_script/npm_and_yarn/npm_lockfile_updater.rb +532 -0
  176. data/lib/dependabot/file_updaters/java_script/npm_and_yarn/npmrc_builder.rb +191 -0
  177. data/lib/dependabot/file_updaters/java_script/npm_and_yarn/package_json_preparer.rb +91 -0
  178. data/lib/dependabot/file_updaters/java_script/npm_and_yarn/package_json_updater.rb +220 -0
  179. data/lib/dependabot/file_updaters/java_script/npm_and_yarn/yarn_lockfile_updater.rb +475 -0
  180. data/lib/dependabot/file_updaters/php/composer.rb +78 -0
  181. data/lib/dependabot/file_updaters/php/composer/lockfile_updater.rb +264 -0
  182. data/lib/dependabot/file_updaters/php/composer/manifest_updater.rb +70 -0
  183. data/lib/dependabot/file_updaters/python/pip.rb +147 -0
  184. data/lib/dependabot/file_updaters/python/pip/pip_compile_file_updater.rb +363 -0
  185. data/lib/dependabot/file_updaters/python/pip/pipfile_file_updater.rb +397 -0
  186. data/lib/dependabot/file_updaters/python/pip/pipfile_preparer.rb +125 -0
  187. data/lib/dependabot/file_updaters/python/pip/poetry_file_updater.rb +289 -0
  188. data/lib/dependabot/file_updaters/python/pip/pyproject_preparer.rb +105 -0
  189. data/lib/dependabot/file_updaters/python/pip/requirement_file_updater.rb +166 -0
  190. data/lib/dependabot/file_updaters/python/pip/requirement_replacer.rb +95 -0
  191. data/lib/dependabot/file_updaters/python/pip/setup_file_sanitizer.rb +91 -0
  192. data/lib/dependabot/file_updaters/ruby/bundler.rb +121 -0
  193. data/lib/dependabot/file_updaters/ruby/bundler/gemfile_updater.rb +116 -0
  194. data/lib/dependabot/file_updaters/ruby/bundler/gemspec_dependency_name_finder.rb +52 -0
  195. data/lib/dependabot/file_updaters/ruby/bundler/gemspec_sanitizer.rb +298 -0
  196. data/lib/dependabot/file_updaters/ruby/bundler/gemspec_updater.rb +64 -0
  197. data/lib/dependabot/file_updaters/ruby/bundler/git_pin_replacer.rb +80 -0
  198. data/lib/dependabot/file_updaters/ruby/bundler/git_source_remover.rb +102 -0
  199. data/lib/dependabot/file_updaters/ruby/bundler/lockfile_updater.rb +384 -0
  200. data/lib/dependabot/file_updaters/ruby/bundler/requirement_replacer.rb +188 -0
  201. data/lib/dependabot/file_updaters/rust/cargo.rb +83 -0
  202. data/lib/dependabot/file_updaters/rust/cargo/lockfile_updater.rb +251 -0
  203. data/lib/dependabot/file_updaters/rust/cargo/manifest_updater.rb +162 -0
  204. data/lib/dependabot/git_commit_checker.rb +412 -0
  205. data/lib/dependabot/metadata_finders.rb +46 -0
  206. data/lib/dependabot/metadata_finders/README.md +53 -0
  207. data/lib/dependabot/metadata_finders/base.rb +117 -0
  208. data/lib/dependabot/metadata_finders/base/changelog_finder.rb +317 -0
  209. data/lib/dependabot/metadata_finders/base/changelog_pruner.rb +177 -0
  210. data/lib/dependabot/metadata_finders/base/commits_finder.rb +217 -0
  211. data/lib/dependabot/metadata_finders/base/release_finder.rb +251 -0
  212. data/lib/dependabot/metadata_finders/docker/docker.rb +18 -0
  213. data/lib/dependabot/metadata_finders/dotnet/nuget.rb +116 -0
  214. data/lib/dependabot/metadata_finders/elixir/hex.rb +69 -0
  215. data/lib/dependabot/metadata_finders/elm/elm_package.rb +22 -0
  216. data/lib/dependabot/metadata_finders/git/submodules.rb +20 -0
  217. data/lib/dependabot/metadata_finders/go/dep.rb +56 -0
  218. data/lib/dependabot/metadata_finders/java/maven.rb +173 -0
  219. data/lib/dependabot/metadata_finders/java_script/npm_and_yarn.rb +215 -0
  220. data/lib/dependabot/metadata_finders/php/composer.rb +66 -0
  221. data/lib/dependabot/metadata_finders/python/pip.rb +120 -0
  222. data/lib/dependabot/metadata_finders/ruby/bundler.rb +150 -0
  223. data/lib/dependabot/metadata_finders/rust/cargo.rb +64 -0
  224. data/lib/dependabot/pull_request_creator.rb +151 -0
  225. data/lib/dependabot/pull_request_creator/branch_namer.rb +170 -0
  226. data/lib/dependabot/pull_request_creator/commit_signer.rb +63 -0
  227. data/lib/dependabot/pull_request_creator/github.rb +233 -0
  228. data/lib/dependabot/pull_request_creator/gitlab.rb +122 -0
  229. data/lib/dependabot/pull_request_creator/labeler.rb +361 -0
  230. data/lib/dependabot/pull_request_creator/message_builder.rb +888 -0
  231. data/lib/dependabot/pull_request_updater.rb +43 -0
  232. data/lib/dependabot/pull_request_updater/github.rb +151 -0
  233. data/lib/dependabot/shared_helpers.rb +201 -0
  234. data/lib/dependabot/source.rb +120 -0
  235. data/lib/dependabot/update_checkers.rb +48 -0
  236. data/lib/dependabot/update_checkers/README.md +67 -0
  237. data/lib/dependabot/update_checkers/base.rb +220 -0
  238. data/lib/dependabot/update_checkers/docker/docker.rb +290 -0
  239. data/lib/dependabot/update_checkers/dotnet/nuget.rb +127 -0
  240. data/lib/dependabot/update_checkers/dotnet/nuget/property_updater.rb +97 -0
  241. data/lib/dependabot/update_checkers/dotnet/nuget/repository_finder.rb +232 -0
  242. data/lib/dependabot/update_checkers/dotnet/nuget/requirements_updater.rb +81 -0
  243. data/lib/dependabot/update_checkers/dotnet/nuget/version_finder.rb +231 -0
  244. data/lib/dependabot/update_checkers/elixir/hex.rb +274 -0
  245. data/lib/dependabot/update_checkers/elixir/hex/file_preparer.rb +193 -0
  246. data/lib/dependabot/update_checkers/elixir/hex/requirements_updater.rb +177 -0
  247. data/lib/dependabot/update_checkers/elixir/hex/version_resolver.rb +175 -0
  248. data/lib/dependabot/update_checkers/elm/elm_package.rb +126 -0
  249. data/lib/dependabot/update_checkers/elm/elm_package/cli_parser.rb +33 -0
  250. data/lib/dependabot/update_checkers/elm/elm_package/elm_18_version_resolver.rb +234 -0
  251. data/lib/dependabot/update_checkers/elm/elm_package/elm_19_version_resolver.rb +198 -0
  252. data/lib/dependabot/update_checkers/elm/elm_package/requirements_updater.rb +75 -0
  253. data/lib/dependabot/update_checkers/git/submodules.rb +52 -0
  254. data/lib/dependabot/update_checkers/go/dep.rb +311 -0
  255. data/lib/dependabot/update_checkers/go/dep/file_preparer.rb +221 -0
  256. data/lib/dependabot/update_checkers/go/dep/latest_version_finder.rb +169 -0
  257. data/lib/dependabot/update_checkers/go/dep/requirements_updater.rb +223 -0
  258. data/lib/dependabot/update_checkers/go/dep/version_resolver.rb +164 -0
  259. data/lib/dependabot/update_checkers/go/modules.rb +112 -0
  260. data/lib/dependabot/update_checkers/java/gradle.rb +148 -0
  261. data/lib/dependabot/update_checkers/java/gradle/multi_dependency_updater.rb +105 -0
  262. data/lib/dependabot/update_checkers/java/gradle/version_finder.rb +183 -0
  263. data/lib/dependabot/update_checkers/java/maven.rb +159 -0
  264. data/lib/dependabot/update_checkers/java/maven/property_updater.rb +127 -0
  265. data/lib/dependabot/update_checkers/java/maven/requirements_updater.rb +92 -0
  266. data/lib/dependabot/update_checkers/java/maven/version_finder.rb +225 -0
  267. data/lib/dependabot/update_checkers/java_script/npm_and_yarn.rb +280 -0
  268. data/lib/dependabot/update_checkers/java_script/npm_and_yarn/latest_version_finder.rb +342 -0
  269. data/lib/dependabot/update_checkers/java_script/npm_and_yarn/library_detector.rb +69 -0
  270. data/lib/dependabot/update_checkers/java_script/npm_and_yarn/registry_finder.rb +226 -0
  271. data/lib/dependabot/update_checkers/java_script/npm_and_yarn/requirements_updater.rb +197 -0
  272. data/lib/dependabot/update_checkers/java_script/npm_and_yarn/subdependency_version_resolver.rb +228 -0
  273. data/lib/dependabot/update_checkers/java_script/npm_and_yarn/version_resolver.rb +452 -0
  274. data/lib/dependabot/update_checkers/php/composer.rb +165 -0
  275. data/lib/dependabot/update_checkers/php/composer/requirements_updater.rb +243 -0
  276. data/lib/dependabot/update_checkers/php/composer/version_resolver.rb +203 -0
  277. data/lib/dependabot/update_checkers/python/pip.rb +227 -0
  278. data/lib/dependabot/update_checkers/python/pip/latest_version_finder.rb +252 -0
  279. data/lib/dependabot/update_checkers/python/pip/pip_compile_version_resolver.rb +380 -0
  280. data/lib/dependabot/update_checkers/python/pip/pipfile_version_resolver.rb +559 -0
  281. data/lib/dependabot/update_checkers/python/pip/poetry_version_resolver.rb +300 -0
  282. data/lib/dependabot/update_checkers/python/pip/requirements_updater.rb +367 -0
  283. data/lib/dependabot/update_checkers/ruby/bundler.rb +324 -0
  284. data/lib/dependabot/update_checkers/ruby/bundler/file_preparer.rb +278 -0
  285. data/lib/dependabot/update_checkers/ruby/bundler/force_updater.rb +261 -0
  286. data/lib/dependabot/update_checkers/ruby/bundler/latest_version_finder.rb +169 -0
  287. data/lib/dependabot/update_checkers/ruby/bundler/requirements_updater.rb +264 -0
  288. data/lib/dependabot/update_checkers/ruby/bundler/ruby_requirement_setter.rb +115 -0
  289. data/lib/dependabot/update_checkers/ruby/bundler/shared_bundler_helpers.rb +243 -0
  290. data/lib/dependabot/update_checkers/ruby/bundler/version_resolver.rb +255 -0
  291. data/lib/dependabot/update_checkers/rust/cargo.rb +282 -0
  292. data/lib/dependabot/update_checkers/rust/cargo/file_preparer.rb +202 -0
  293. data/lib/dependabot/update_checkers/rust/cargo/requirements_updater.rb +175 -0
  294. data/lib/dependabot/update_checkers/rust/cargo/version_resolver.rb +242 -0
  295. data/lib/dependabot/utils.rb +84 -0
  296. data/lib/dependabot/utils/docker/credentials_finder.rb +65 -0
  297. data/lib/dependabot/utils/dotnet/requirement.rb +90 -0
  298. data/lib/dependabot/utils/dotnet/version.rb +22 -0
  299. data/lib/dependabot/utils/elixir/requirement.rb +53 -0
  300. data/lib/dependabot/utils/elixir/version.rb +59 -0
  301. data/lib/dependabot/utils/elm/requirement.rb +92 -0
  302. data/lib/dependabot/utils/elm/version.rb +19 -0
  303. data/lib/dependabot/utils/go/path_converter.rb +74 -0
  304. data/lib/dependabot/utils/go/requirement.rb +152 -0
  305. data/lib/dependabot/utils/go/shared_helper.rb +20 -0
  306. data/lib/dependabot/utils/go/version.rb +40 -0
  307. data/lib/dependabot/utils/java/requirement.rb +110 -0
  308. data/lib/dependabot/utils/java/version.rb +179 -0
  309. data/lib/dependabot/utils/java_script/requirement.rb +117 -0
  310. data/lib/dependabot/utils/java_script/version.rb +30 -0
  311. data/lib/dependabot/utils/php/requirement.rb +97 -0
  312. data/lib/dependabot/utils/php/version.rb +22 -0
  313. data/lib/dependabot/utils/python/requirement.rb +130 -0
  314. data/lib/dependabot/utils/python/version.rb +88 -0
  315. data/lib/dependabot/utils/ruby/requirement.rb +26 -0
  316. data/lib/dependabot/utils/rust/requirement.rb +108 -0
  317. data/lib/dependabot/utils/rust/version.rb +32 -0
  318. data/lib/dependabot/version.rb +5 -0
  319. data/lib/python_requirement_parser.rb +33 -0
  320. data/lib/python_versions.rb +21 -0
  321. metadata +641 -0
Binary file
@@ -0,0 +1,4 @@
1
+ php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
2
+ php -r "if (hash_file('SHA384', 'composer-setup.php') === '544e09ee996cdf60ece3804abc52599c22b1f40f4323403c44d44fdfdd586475ca9813a858088ffbc1f233e9b180f061') { echo 'Installer verified'; } else { echo hash_file('SHA384', 'composer-setup.php'); unlink('composer-setup.php'); } echo PHP_EOL;"
3
+ php composer-setup.php
4
+ php -r "unlink('composer-setup.php');"
@@ -0,0 +1,61 @@
1
+ <?php
2
+
3
+ declare(strict_types=1);
4
+
5
+ namespace Dependabot\PHP;
6
+
7
+ use Composer\DependencyResolver\Operation\InstallOperation;
8
+ use Composer\DependencyResolver\Operation\UninstallOperation;
9
+ use Composer\DependencyResolver\Operation\UpdateOperation;
10
+ use Composer\Installer\InstallationManager;
11
+ use Composer\Package\PackageInterface;
12
+ use Composer\Repository\RepositoryInterface;
13
+
14
+ class DependabotInstallationManager extends InstallationManager
15
+ {
16
+ private $installed = [];
17
+ private $updated = [];
18
+ private $uninstalled = [];
19
+
20
+ public function install(RepositoryInterface $repo, InstallOperation $operation): void
21
+ {
22
+ parent::install($repo, $operation);
23
+ $this->installed[] = $operation->getPackage();
24
+ }
25
+
26
+ public function update(RepositoryInterface $repo, UpdateOperation $operation): void
27
+ {
28
+ parent::update($repo, $operation);
29
+ $this->updated[] = [$operation->getInitialPackage(), $operation->getTargetPackage()];
30
+ }
31
+
32
+ public function uninstall(RepositoryInterface $repo, UninstallOperation $operation): void
33
+ {
34
+ parent::uninstall($repo, $operation);
35
+ $this->uninstalled[] = $operation->getPackage();
36
+ }
37
+
38
+ /**
39
+ * @return PackageInterface[]
40
+ */
41
+ public function getInstalledPackages(): array
42
+ {
43
+ return $this->installed;
44
+ }
45
+
46
+ /**
47
+ * @return PackageInterface[]
48
+ */
49
+ public function getUpdatedPackages(): array
50
+ {
51
+ return $this->updated;
52
+ }
53
+
54
+ /**
55
+ * @return PackageInterface[]
56
+ */
57
+ public function getUninstalledPackages(): array
58
+ {
59
+ return $this->uninstalled;
60
+ }
61
+ }
@@ -0,0 +1,23 @@
1
+ <?php
2
+
3
+ declare(strict_types=1);
4
+
5
+ namespace Dependabot\PHP;
6
+
7
+ use Composer\Package\PackageInterface;
8
+ use Composer\Plugin\PluginManager;
9
+
10
+ class DependabotPluginManager extends PluginManager
11
+ {
12
+ public function registerPackage(PackageInterface $package, $failOnMissingClasses = false): void
13
+ {
14
+ // This package does some setup for PHP_CodeSniffer, but errors out the
15
+ // install if Symfony isn't installed (which it won't be for a lockfile
16
+ // only install run). Safe to ignore
17
+ if (strpos($package->getName(), 'phpcodesniffer') !== false) {
18
+ return;
19
+ }
20
+
21
+ parent::registerPackage($package, $failOnMissingClasses);
22
+ }
23
+ }
@@ -0,0 +1,25 @@
1
+ <?php
2
+
3
+ declare(strict_types=1);
4
+
5
+ namespace Dependabot\PHP;
6
+
7
+ use Composer\IO\NullIO;
8
+
9
+ class ExceptionIO extends NullIO
10
+ {
11
+ private $raise_next_error = false;
12
+
13
+ public function writeError($messages, $newline = true, $verbosity = self::NORMAL): void
14
+ {
15
+ if (is_array($messages)) {
16
+ return;
17
+ }
18
+ if ($this->raise_next_error) {
19
+ throw new \RuntimeException('Your requirements could not be resolved to an installable set of packages.' . $messages);
20
+ }
21
+ if (strpos($messages, 'Your requirements could not be resolved') !== false) {
22
+ $this->raise_next_error = true;
23
+ }
24
+ }
25
+ }
@@ -0,0 +1,21 @@
1
+ <?php
2
+
3
+ declare(strict_types=1);
4
+
5
+ namespace Dependabot\PHP;
6
+
7
+ use Composer\Factory;
8
+
9
+ class Hasher
10
+ {
11
+ public static function getContentHash(array $args): ?string
12
+ {
13
+ [$workingDirectory] = $args;
14
+
15
+ $io = new ExceptionIO();
16
+ $composer = Factory::create($io, $workingDirectory . '/composer.json');
17
+ $locker = $composer->getLocker();
18
+
19
+ return $locker->getContentHash(file_get_contents(Factory::getComposerFile()));
20
+ }
21
+ }
@@ -0,0 +1,123 @@
1
+ <?php
2
+
3
+ declare(strict_types=1);
4
+
5
+ namespace Dependabot\PHP;
6
+
7
+ use Composer\Factory;
8
+ use Composer\Installer;
9
+ use Composer\Package\PackageInterface;
10
+
11
+ class UpdateChecker
12
+ {
13
+ public static function getLatestResolvableVersion(array $args): ?string
14
+ {
15
+ [$workingDirectory, $dependencyName, $gitCredentials, $registryCredentials] = $args;
16
+
17
+ $io = new ExceptionIO();
18
+ $composer = Factory::create($io, $workingDirectory . '/composer.json');
19
+ $config = $composer->getConfig();
20
+ $httpBasicCredentials = [];
21
+
22
+ foreach ($gitCredentials as &$cred) {
23
+ $httpBasicCredentials[$cred['host']] = [
24
+ 'username' => $cred['username'],
25
+ 'password' => $cred['password'],
26
+ ];
27
+ }
28
+
29
+ foreach ($registryCredentials as &$cred) {
30
+ $httpBasicCredentials[$cred['registry']] = [
31
+ 'username' => $cred['username'],
32
+ 'password' => $cred['password'],
33
+ ];
34
+ }
35
+
36
+ if ($httpBasicCredentials) {
37
+ $config->merge(
38
+ [
39
+ 'config' => [
40
+ 'http-basic' => $httpBasicCredentials,
41
+ ],
42
+ ]
43
+ );
44
+ $io->loadConfiguration($config);
45
+ }
46
+
47
+ $installationManager = new DependabotInstallationManager();
48
+ $install = new Installer(
49
+ $io,
50
+ $config,
51
+ $composer->getPackage(),
52
+ $composer->getDownloadManager(),
53
+ $composer->getRepositoryManager(),
54
+ $composer->getLocker(),
55
+ $installationManager,
56
+ $composer->getEventDispatcher(),
57
+ $composer->getAutoloadGenerator()
58
+ );
59
+
60
+ // For all potential options, see UpdateCommand in composer
61
+ $install
62
+ ->setDryRun(true)
63
+ ->setUpdate(true)
64
+ ->setDevMode(true)
65
+ ->setUpdateWhitelist([$dependencyName])
66
+ ->setWhitelistTransitiveDependencies(true)
67
+ ->setExecuteOperations(false)
68
+ ->setDumpAutoloader(false)
69
+ ->setRunScripts(false);
70
+
71
+ /*
72
+ * If a platform is set we assume people know what they are doing and we respect the setting.
73
+ * If no platform is set we ignore it so that the php we run as doesn't interfere
74
+ */
75
+ if ($config->get('platform') === []) {
76
+ $install->setIgnorePlatformRequirements(true);
77
+ }
78
+
79
+ $install->run();
80
+
81
+ $installedPackages = $installationManager->getInstalledPackages();
82
+
83
+ $updatedPackage = current(array_filter($installedPackages, function (PackageInterface $package) use ($dependencyName) {
84
+ return $package->getName() == $dependencyName;
85
+ }));
86
+
87
+ // We found the package in the list of updated packages. Return its version.
88
+ if ($updatedPackage) {
89
+ return preg_replace('/^([v])/', '', $updatedPackage->getPrettyVersion());
90
+ }
91
+
92
+ // We didn't find the package in the list of updated packages. Check if
93
+ // it was replaced by another package (in which case we can ignore).
94
+ foreach ($composer->getPackage()->getReplaces() as $link) {
95
+ if ($link->getTarget() == $dependencyName) {
96
+ return null;
97
+ }
98
+ }
99
+ foreach ($installedPackages as $package) {
100
+ foreach ($package->getReplaces() as $link) {
101
+ if ($link->getTarget() == $dependencyName) {
102
+ return null;
103
+ }
104
+ }
105
+ }
106
+
107
+ // Similarly, check if the package was provided by any other package.
108
+ foreach ($composer->getPackage()->getProvides() as $link) {
109
+ if ($link->getTarget() == $dependencyName) {
110
+ return preg_replace('/^([v])/', '', $link->getPrettyConstraint());
111
+ }
112
+ }
113
+ foreach ($installedPackages as $package) {
114
+ foreach ($package->getProvides() as $link) {
115
+ if ($link->getTarget() == $dependencyName) {
116
+ return preg_replace('/^([v])/', '', $link->getPrettyConstraint());
117
+ }
118
+ }
119
+ }
120
+
121
+ throw new \RuntimeException('Package not found in updated packages!');
122
+ }
123
+ }
@@ -0,0 +1,97 @@
1
+ <?php
2
+
3
+ declare(strict_types=1);
4
+
5
+ namespace Dependabot\PHP;
6
+
7
+ use Composer\Factory;
8
+ use Composer\Installer;
9
+
10
+ class Updater
11
+ {
12
+ public static function update(array $args): array
13
+ {
14
+ [$workingDirectory, $dependencyName, $dependencyVersion, $gitCredentials, $registryCredentials] = $args;
15
+
16
+ // Change working directory to the one provided, this ensures that we
17
+ // install dependencies into the working dir, rather than a vendor folder
18
+ // in the root of the project
19
+ $originalDir = getcwd();
20
+ chdir($workingDirectory);
21
+
22
+ $io = new ExceptionIO();
23
+ $composer = Factory::create($io);
24
+ $config = $composer->getConfig();
25
+ $httpBasicCredentials = [];
26
+
27
+ $pm = new DependabotPluginManager($io, $composer, null, false);
28
+ $composer->setPluginManager($pm);
29
+ $pm->loadInstalledPlugins();
30
+
31
+ foreach ($gitCredentials as &$cred) {
32
+ $httpBasicCredentials[$cred['host']] = [
33
+ 'username' => $cred['username'],
34
+ 'password' => $cred['password'],
35
+ ];
36
+ }
37
+
38
+ foreach ($registryCredentials as &$cred) {
39
+ $httpBasicCredentials[$cred['registry']] = [
40
+ 'username' => $cred['username'],
41
+ 'password' => $cred['password'],
42
+ ];
43
+ }
44
+
45
+ if ($httpBasicCredentials) {
46
+ $config->merge(
47
+ [
48
+ 'config' => [
49
+ 'http-basic' => $httpBasicCredentials,
50
+ ],
51
+ ]
52
+ );
53
+ $io->loadConfiguration($config);
54
+ }
55
+
56
+ $install = new Installer(
57
+ $io,
58
+ $config,
59
+ $composer->getPackage(),
60
+ $composer->getDownloadManager(),
61
+ $composer->getRepositoryManager(),
62
+ $composer->getLocker(),
63
+ $composer->getInstallationManager(),
64
+ $composer->getEventDispatcher(),
65
+ $composer->getAutoloadGenerator()
66
+ );
67
+
68
+ // For all potential options, see UpdateCommand in composer
69
+ $install
70
+ ->setWriteLock(true)
71
+ ->setUpdate(true)
72
+ ->setDevMode(true)
73
+ ->setUpdateWhitelist([$dependencyName])
74
+ ->setWhitelistTransitiveDependencies(true)
75
+ ->setExecuteOperations(false)
76
+ ->setDumpAutoloader(false)
77
+ ->setRunScripts(false);
78
+
79
+ /*
80
+ * If a platform is set we assume people know what they are doing and we respect the setting.
81
+ * If no platform is set we ignore it so that the php we run as doesn't interfere
82
+ */
83
+ if ($config->get('platform') === []) {
84
+ $install->setIgnorePlatformRequirements(true);
85
+ }
86
+
87
+ $install->run();
88
+
89
+ $result = [
90
+ 'composer.lock' => file_get_contents('composer.lock'),
91
+ ];
92
+
93
+ chdir($originalDir);
94
+
95
+ return $result;
96
+ }
97
+ }
File without changes
@@ -0,0 +1,23 @@
1
+ import hashin
2
+ import json
3
+ import pipfile
4
+ from poetry.poetry import Poetry
5
+
6
+ def get_dependency_hash(dependency_name, dependency_version, algorithm):
7
+ hashes = hashin.get_package_hashes(
8
+ dependency_name,
9
+ version=dependency_version,
10
+ algorithm=algorithm
11
+ )
12
+
13
+ return json.dumps({ "result": hashes["hashes"] })
14
+
15
+ def get_pipfile_hash(directory):
16
+ p = pipfile.load(directory + '/Pipfile')
17
+
18
+ return json.dumps({ "result": p.hash })
19
+
20
+ def get_pyproject_hash(directory):
21
+ p = Poetry.create(directory)
22
+
23
+ return json.dumps({ "result": p.locker._get_content_hash() })
@@ -0,0 +1,130 @@
1
+ from itertools import chain
2
+ import glob
3
+ import io
4
+ import json
5
+ import os.path
6
+ import re
7
+
8
+ import setuptools
9
+ import pip._internal.req.req_file
10
+ from pip._internal.download import PipSession
11
+ from pip._internal.req.constructors import install_req_from_line
12
+
13
+ def parse_requirements(directory):
14
+ # Parse the requirements.txt
15
+ requirement_packages = []
16
+
17
+ requirement_files = glob.glob(os.path.join(directory, '*.txt')) \
18
+ + glob.glob(os.path.join(directory, '**', '*.txt'))
19
+
20
+ pip_compile_files = glob.glob(os.path.join(directory, '*.in')) \
21
+ + glob.glob(os.path.join(directory, '**', '*.in'))
22
+
23
+ for reqs_file in requirement_files + pip_compile_files:
24
+ try:
25
+ requirements = pip._internal.req.req_file.parse_requirements(
26
+ reqs_file,
27
+ session=PipSession()
28
+ )
29
+ for install_req in requirements:
30
+ if install_req.original_link:
31
+ continue
32
+ if install_req.is_pinned:
33
+ version = next(iter(install_req.specifier)).version
34
+ else:
35
+ version = None
36
+
37
+ pattern = r"-[cr] (.*) \(line \d+\)"
38
+ abs_path = re.search(pattern, install_req.comes_from).group(1)
39
+ rel_path = os.path.relpath(abs_path, directory)
40
+
41
+ requirement_packages.append({
42
+ "name": install_req.req.name,
43
+ "version": version,
44
+ "markers": str(install_req.markers) or None,
45
+ "file": rel_path,
46
+ "requirement": str(install_req.specifier) or None
47
+ })
48
+ except Exception as e:
49
+ print(json.dumps({ "error": repr(e) }))
50
+ exit(1)
51
+
52
+ return json.dumps({ "result": requirement_packages })
53
+
54
+ def parse_setup(directory):
55
+ # Parse the setup.py
56
+ setup_packages = []
57
+ if os.path.isfile(directory + '/setup.py'):
58
+ def parse_requirement(req, req_type):
59
+ install_req = install_req_from_line(req)
60
+ if install_req.original_link:
61
+ return
62
+ if install_req.is_pinned:
63
+ version = next(iter(install_req.specifier)).version
64
+ else:
65
+ version = None
66
+ setup_packages.append({
67
+ "name": install_req.req.name,
68
+ "version": version,
69
+ "markers": str(install_req.markers) or None,
70
+ "file": "setup.py",
71
+ "requirement": str(install_req.specifier) or None,
72
+ "requirement_type": req_type
73
+ })
74
+
75
+ def setup(*args, **kwargs):
76
+ for arg in ['setup_requires', 'install_requires', 'tests_require']:
77
+ if not kwargs.get(arg):
78
+ continue
79
+ for req in kwargs.get(arg):
80
+ parse_requirement(req, arg)
81
+ extras_require_dict = kwargs.get('extras_require', {})
82
+ for key in extras_require_dict:
83
+ for req in extras_require_dict[key]:
84
+ parse_requirement(req, 'extras_require:{}'.format(key))
85
+ setuptools.setup = setup
86
+
87
+ def noop(*args, **kwargs):
88
+ pass
89
+
90
+ def fake_parse(*args, **kwargs):
91
+ return []
92
+
93
+ global fake_open
94
+ def fake_open(*args, **kwargs):
95
+ content = ("VERSION = (0, 0, 1)\n"
96
+ "__version__ = '0.0.1'\n"
97
+ "__author__ = 'someone'\n"
98
+ "__title__ = 'something'\n"
99
+ "__description__ = 'something'\n"
100
+ "__author_email__ = 'something'\n"
101
+ "__license__ = 'something'\n"
102
+ "__url__ = 'something'\n")
103
+ return io.StringIO(content)
104
+
105
+ content = open(directory + '/setup.py', 'r').read()
106
+
107
+ # Remove `print`, `open`, `log` and import statements
108
+ content = re.sub(r"print\s*\(", "noop(", content)
109
+ content = re.sub(r"log\s*(\.\w+)*\(", "noop(", content)
110
+ content = re.sub(r"\b(\w+\.)*(open|file)\s*\(", "fake_open(", content)
111
+ content = content.replace("parse_requirements(", "fake_parse(")
112
+ version_re = re.compile(r"^.*import.*__version__.*$", re.MULTILINE)
113
+ content = re.sub(version_re, "", content)
114
+
115
+ # Set variables likely to be imported
116
+ __version__ = '0.0.1'
117
+ __author__ = 'someone'
118
+ __title__ = 'something'
119
+ __description__ = 'something'
120
+ __author_email__ = 'something'
121
+ __license__ = 'something'
122
+ __url__ = 'something'
123
+
124
+ # Run as main (since setup.py is a script)
125
+ __name__ = '__main__'
126
+
127
+ # Exec the setup.py
128
+ exec(content) in globals(), locals()
129
+
130
+ return json.dumps({ "result": setup_packages })