Module: Gitlab::Regex::Packages
- Includes:
- Utils::StrongMemoize
- Included in:
- Gitlab::Regex
- Defined in:
- lib/gitlab/regex/packages.rb,
lib/gitlab/regex/packages/protection/rules.rb
Defined Under Namespace
Modules: Protection
Constant Summary collapse
- CONAN_RECIPE_FILES =
%w[conanfile.py conanmanifest.txt conan_sources.tgz conan_export.tgz].freeze
- CONAN_PACKAGE_FILES =
%w[conaninfo.txt conanmanifest.txt conan_package.tgz].freeze
- PYPI_NORMALIZED_NAME_REGEX_STRING =
'[-_.]+'
- MAVEN_SNAPSHOT_DYNAMIC_PARTS =
/\A.{0,1000}(-\d{8}\.\d{6}-\d+).{0,1000}\z/
- API_PATH_REGEX =
%r{^/api/v\d+/(projects/[^/]+/|groups?/[^/]+/-/)?packages/[A-Za-z]+}
Instance Method Summary collapse
-
#_semver_major_minor_patch_regex ⇒ Object
These partial semver regexes are intended for use in composing other regexes rather than being used alone.
- #_semver_major_regex ⇒ Object
- #_semver_minor_regex ⇒ Object
- #_semver_patch_regex ⇒ Object
- #_semver_prerelease_build_regex ⇒ Object
- #composer_dev_version_regex ⇒ Object
- #composer_package_version_regex ⇒ Object
- #conan_package_reference_regex ⇒ Object
- #conan_recipe_component_regex ⇒ Object
- #conan_recipe_user_channel_regex ⇒ Object
- #conan_revision_regex ⇒ Object
- #conan_revision_regex_v2 ⇒ Object
- #debian_architecture_regex ⇒ Object
- #debian_component_regex ⇒ Object
- #debian_direct_upload_filename_regex ⇒ Object
- #debian_distribution_regex ⇒ Object
- #debian_package_name_regex ⇒ Object
- #debian_version_regex ⇒ Object
- #generic_package_file_name_regex ⇒ Object
- #generic_package_name_regex ⇒ Object
- #generic_package_version_regex ⇒ Object
- #go_package_regex ⇒ Object
- #helm_channel_regex ⇒ Object
- #helm_index_app_version_quote_regex ⇒ Object
- #helm_package_regex ⇒ Object
- #helm_version_regex ⇒ Object
- #maven_app_group_regex ⇒ Object
- #maven_app_name_regex ⇒ Object
- #maven_file_name_regex ⇒ Object
- #maven_path_regex ⇒ Object
- #maven_version_regex ⇒ Object
- #npm_package_name_regex(other_accepted_chars = nil) ⇒ Object
- #npm_package_name_regex_message ⇒ Object
- #nuget_package_name_regex ⇒ Object
- #nuget_version_regex ⇒ Object
- #package_name_regex(other_accepted_chars_package_name = nil) ⇒ Object
- #prefixed_semver_regex ⇒ Object
- #pypi_version_regex ⇒ Object
- #semver_regex ⇒ Object
- #semver_regex_message ⇒ Object
- #sha256_regex ⇒ Object
- #slack_link_regex ⇒ Object
- #terraform_module_package_name_regex ⇒ Object
- #unbounded_semver_regex ⇒ Object
Instance Method Details
#_semver_major_minor_patch_regex ⇒ Object
These partial semver regexes are intended for use in composing other regexes rather than being used alone.
203 204 205 206 207 |
# File 'lib/gitlab/regex/packages.rb', line 203 def _semver_major_minor_patch_regex @_semver_major_minor_patch_regex ||= / #{_semver_major_regex}\.#{_semver_minor_regex}\.#{_semver_patch_regex} /x end |
#_semver_major_regex ⇒ Object
209 210 211 212 213 |
# File 'lib/gitlab/regex/packages.rb', line 209 def _semver_major_regex @_semver_major_regex ||= / (?<major>0|[1-9]\d*) /x end |
#_semver_minor_regex ⇒ Object
215 216 217 218 219 |
# File 'lib/gitlab/regex/packages.rb', line 215 def _semver_minor_regex @_semver_minor_regex ||= / (?<minor>0|[1-9]\d*) /x end |
#_semver_patch_regex ⇒ Object
221 222 223 224 225 |
# File 'lib/gitlab/regex/packages.rb', line 221 def _semver_patch_regex @_semver_patch_regex ||= / (?<patch>0|[1-9]\d*) /x end |
#_semver_prerelease_build_regex ⇒ Object
227 228 229 230 231 232 |
# File 'lib/gitlab/regex/packages.rb', line 227 def _semver_prerelease_build_regex @_semver_prerelease_build_regex ||= / (?:-(?<prerelease>(?:\d*[a-zA-Z-][0-9a-zA-Z-]*|[1-9]\d*|0)(?:\.(?:\d*[a-zA-Z-][0-9a-zA-Z-]*|[1-9]\d*|0))*))? (?:\+(?<build>[0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))? /x end |
#composer_dev_version_regex ⇒ Object
48 49 50 |
# File 'lib/gitlab/regex/packages.rb', line 48 def composer_dev_version_regex @composer_dev_version_regex ||= %r{(^dev-)|(-dev$)} end |
#composer_package_version_regex ⇒ Object
43 44 45 46 |
# File 'lib/gitlab/regex/packages.rb', line 43 def composer_package_version_regex # see https://github.com/composer/semver/blob/31f3ea725711245195f62e54ffa402d8ef2fdba9/src/VersionParser.php#L215 @composer_package_version_regex ||= %r{\Av?((\d++)(\.(?:\d++|[xX*]))?(\.(?:\d++|[xX*]))?(\.(?:\d++|[xX*]))?)?\z} end |
#conan_package_reference_regex ⇒ Object
18 19 20 |
# File 'lib/gitlab/regex/packages.rb', line 18 def conan_package_reference_regex @conan_package_reference_regex ||= %r{\A[A-Za-z0-9]+\z} end |
#conan_recipe_component_regex ⇒ Object
38 39 40 41 |
# File 'lib/gitlab/regex/packages.rb', line 38 def conan_recipe_component_regex # https://docs.conan.io/en/latest/reference/conanfile/attributes.html#name @conan_recipe_component_regex ||= %r{\A#{conan_name_regex}\z} end |
#conan_recipe_user_channel_regex ⇒ Object
34 35 36 |
# File 'lib/gitlab/regex/packages.rb', line 34 def conan_recipe_user_channel_regex %r{\A(_|#{conan_name_regex})\z} end |
#conan_revision_regex ⇒ Object
22 23 24 |
# File 'lib/gitlab/regex/packages.rb', line 22 def conan_revision_regex @conan_revision_regex ||= %r{\A0\z} end |
#conan_revision_regex_v2 ⇒ Object
26 27 28 29 30 31 32 |
# File 'lib/gitlab/regex/packages.rb', line 26 def conan_revision_regex_v2 # The revision can be one of two types: # - "hash" (default): the checksum hash of the recipe manifest: MD5 Hash 32 Characters # - "scm" or "scm_folder": the commit ID for the repository system (Git or SVN): SHA-1 Hash 40 Characters # according to https://docs.conan.io/2.10/reference/conanfile/attributes.html#revision-mode @conan_revision_regex_v2 ||= %r/\A(?:\h{32}|\h{40})\z/ end |
#debian_architecture_regex ⇒ Object
151 152 153 154 155 |
# File 'lib/gitlab/regex/packages.rb', line 151 def debian_architecture_regex # See official parser: https://git.dpkg.org/cgit/dpkg/dpkg.git/tree/lib/dpkg/arch.c?id=9e0c88ec09475f4d1addde9cdba1ad7849720356#n43 # But we limit to lower case @debian_architecture_regex ||= %r{\A#{::Packages::Debian::ARCHITECTURE_REGEX}\z}o end |
#debian_component_regex ⇒ Object
161 162 163 |
# File 'lib/gitlab/regex/packages.rb', line 161 def debian_component_regex @debian_component_regex ||= %r{\A#{::Packages::Debian::COMPONENT_REGEX}\z}o end |
#debian_direct_upload_filename_regex ⇒ Object
165 166 167 |
# File 'lib/gitlab/regex/packages.rb', line 165 def debian_direct_upload_filename_regex @debian_direct_upload_filename_regex ||= %r{\A.*\.(deb|udeb|ddeb)\z}o end |
#debian_distribution_regex ⇒ Object
157 158 159 |
# File 'lib/gitlab/regex/packages.rb', line 157 def debian_distribution_regex @debian_distribution_regex ||= %r{\A#{::Packages::Debian::DISTRIBUTION_REGEX}\z}io end |
#debian_package_name_regex ⇒ Object
131 132 133 134 135 136 137 138 |
# File 'lib/gitlab/regex/packages.rb', line 131 def debian_package_name_regex # See official parser # https://git.dpkg.org/cgit/dpkg/dpkg.git/tree/lib/dpkg/parsehelp.c?id=9e0c88ec09475f4d1addde9cdba1ad7849720356#n122 # @debian_package_name_regex ||= %r{\A[a-z0-9][-+\._a-z0-9]*\z}i.freeze # But we prefer a more strict version from Lintian # https://salsa.debian.org/lintian/lintian/-/blob/5080c0068ffc4a9ddee92022a91d0c2ff53e56d1/lib/Lintian/Util.pm#L116 @debian_package_name_regex ||= %r{\A[a-z0-9][-+\.a-z0-9]+\z} end |
#debian_version_regex ⇒ Object
140 141 142 143 144 145 146 147 148 149 |
# File 'lib/gitlab/regex/packages.rb', line 140 def debian_version_regex # See official parser: https://git.dpkg.org/cgit/dpkg/dpkg.git/tree/lib/dpkg/parsehelp.c?id=9e0c88ec09475f4d1addde9cdba1ad7849720356#n205 @debian_version_regex ||= %r{ \A(?: (?:([0-9]{1,9}):)? (?# epoch) ([0-9][0-9a-z\.+~]*) (?# version) (-[0-9a-z\.+~]+){0,14} (?# -revision) (?<!-) )\z}xi end |
#generic_package_file_name_regex ⇒ Object
270 271 272 |
# File 'lib/gitlab/regex/packages.rb', line 270 def generic_package_file_name_regex @generic_package_file_name_regex ||= /\A(?!~)(?!@)[A-Za-z0-9\.\_\-\+~@]+(?<!~)(?<!@)\z/ end |
#generic_package_name_regex ⇒ Object
266 267 268 |
# File 'lib/gitlab/regex/packages.rb', line 266 def generic_package_name_regex maven_file_name_regex end |
#generic_package_version_regex ⇒ Object
262 263 264 |
# File 'lib/gitlab/regex/packages.rb', line 262 def generic_package_version_regex maven_version_regex end |
#go_package_regex ⇒ Object
239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 |
# File 'lib/gitlab/regex/packages.rb', line 239 def go_package_regex # A Go package name looks like a URL but is not; it: # - Must not have a scheme, such as http:// or https:// # - Must not have a port number, such as :8080 or :8443 @go_package_regex ||= %r{ (?<=^|\s|\() (?# beginning of line, whitespace character, or opening parenthesis) (?<domain> [0-9a-z](?:(?:-|[0-9a-z]){0,61}[0-9a-z]) (?# first domain) (?:\.[0-9a-z](?:(?:-|[0-9a-z]){0,61}[0-9a-z])?){0,49} (?# inner domains) \.[a-z]{2,63}(?=/|\s|$|\)) (?# top-level domain, ends with /, whitespace, or end of line) ) (?<path> /(?: [-/$_.+!*'(),0-9a-z] (?# plain URL character) | %[0-9a-f]{2} (?# URL encoded character) ){0,1000} )? (?# optional path) (?=$|\s|\)) (?# followed by end of line, whitespace, or closing parenthesis) }ix end |
#helm_channel_regex ⇒ Object
169 170 171 |
# File 'lib/gitlab/regex/packages.rb', line 169 def helm_channel_regex @helm_channel_regex ||= %r{\A([a-zA-Z0-9](\.|-|_)?){1,255}(?<!\.|-|_)\z} end |
#helm_index_app_version_quote_regex ⇒ Object
282 283 284 |
# File 'lib/gitlab/regex/packages.rb', line 282 def helm_index_app_version_quote_regex @helm_index_app_version_quote_regex ||= /^(\s*appVersion:\s+)(?!["'])([^\n\r]+)$/m end |
#helm_package_regex ⇒ Object
173 174 175 |
# File 'lib/gitlab/regex/packages.rb', line 173 def helm_package_regex @helm_package_regex ||= %r{#{helm_channel_regex}} end |
#helm_version_regex ⇒ Object
177 178 179 180 |
# File 'lib/gitlab/regex/packages.rb', line 177 def helm_version_regex # identical to semver_regex, with optional preceding 'v' @helm_version_regex ||= Regexp.new("\\Av?#{::Gitlab::Regex.unbounded_semver_regex.source}\\z", ::Gitlab::Regex.unbounded_semver_regex.) end |
#maven_app_group_regex ⇒ Object
84 85 86 |
# File 'lib/gitlab/regex/packages.rb', line 84 def maven_app_group_regex maven_app_name_regex end |
#maven_app_name_regex ⇒ Object
76 77 78 |
# File 'lib/gitlab/regex/packages.rb', line 76 def maven_app_name_regex @maven_app_name_regex ||= /\A[\w\-\.]+\z/ end |
#maven_file_name_regex ⇒ Object
68 69 70 |
# File 'lib/gitlab/regex/packages.rb', line 68 def maven_file_name_regex @maven_file_name_regex ||= %r{\A[A-Za-z0-9\.\_\-\+]+\z} end |
#maven_path_regex ⇒ Object
72 73 74 |
# File 'lib/gitlab/regex/packages.rb', line 72 def maven_path_regex @maven_path_regex ||= %r{\A\@?(([\w\-\.]*)/)*([\w\-\.\+]*)\z} end |
#maven_version_regex ⇒ Object
80 81 82 |
# File 'lib/gitlab/regex/packages.rb', line 80 def maven_version_regex @maven_version_regex ||= /\A(?!.*\.\.)[\w+.-]+\z/ end |
#npm_package_name_regex(other_accepted_chars = nil) ⇒ Object
88 89 90 91 92 |
# File 'lib/gitlab/regex/packages.rb', line 88 def npm_package_name_regex(other_accepted_chars = nil) strong_memoize_with(:npm_package_name_regex, other_accepted_chars) do %r{\A(?:@(#{Gitlab::PathRegex::NAMESPACE_FORMAT_REGEX})/)?[-+\.\_a-zA-Z0-9#{other_accepted_chars}]+\z} end end |
#npm_package_name_regex_message ⇒ Object
94 95 96 |
# File 'lib/gitlab/regex/packages.rb', line 94 def 'should be a valid NPM package name: https://github.com/npm/validate-npm-package-name#naming-rules.' end |
#nuget_package_name_regex ⇒ Object
98 99 100 |
# File 'lib/gitlab/regex/packages.rb', line 98 def nuget_package_name_regex @nuget_package_name_regex ||= %r{\A[-+\.\_a-zA-Z0-9]+\z} end |
#nuget_version_regex ⇒ Object
102 103 104 105 106 107 108 109 110 |
# File 'lib/gitlab/regex/packages.rb', line 102 def nuget_version_regex @nuget_version_regex ||= / \A#{_semver_major_regex} \.#{_semver_minor_regex} (\.#{_semver_patch_regex})? (\.\d*)? #{_semver_prerelease_build_regex}\z /x end |
#package_name_regex(other_accepted_chars_package_name = nil) ⇒ Object
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
# File 'lib/gitlab/regex/packages.rb', line 52 def package_name_regex(other_accepted_chars_package_name = nil) strong_memoize_with(:package_name_regex, other_accepted_chars_package_name) do %r{ \A\@? (?> # atomic group to prevent backtracking (([\w\-\.\+]*)\/)*([\w\-\.]+) ) @? (?> # atomic group to prevent backtracking (([\w\-\.\+]*)\/)*([\w\-\.#{other_accepted_chars_package_name}]*) ) \z }x end end |
#prefixed_semver_regex ⇒ Object
234 235 236 237 |
# File 'lib/gitlab/regex/packages.rb', line 234 def prefixed_semver_regex # identical to semver_regex, except starting with 'v' @prefixed_semver_regex ||= Regexp.new("\\Av#{::Gitlab::Regex.unbounded_semver_regex.source}\\z", ::Gitlab::Regex.unbounded_semver_regex.) end |
#pypi_version_regex ⇒ Object
116 117 118 119 120 121 122 123 124 125 126 127 128 129 |
# File 'lib/gitlab/regex/packages.rb', line 116 def pypi_version_regex # See the official regex: https://github.com/pypa/packaging/blob/16.7/packaging/version.py#L159 @pypi_version_regex ||= %r{ \A(?: v? (?:([0-9]+)!)? (?# epoch) ([0-9]+(?:\.[0-9]+)*) (?# release segment) ([-_\.]?((a|b|c|rc|alpha|beta|pre|preview))[-_\.]?([0-9]+)?)? (?# pre-release) ((?:-([0-9]+))|(?:[-_\.]?(post|rev|r)[-_\.]?([0-9]+)?))? (?# post release) ([-_\.]?(dev)[-_\.]?([0-9]+)?)? (?# dev release) (?:\+([a-z0-9]+(?:[-_\.][a-z0-9]+)*))? (?# local version) )\z}xi end |
#semver_regex ⇒ Object
193 194 195 |
# File 'lib/gitlab/regex/packages.rb', line 193 def semver_regex @semver_regex ||= Regexp.new("\\A#{::Gitlab::Regex.unbounded_semver_regex.source}\\z", ::Gitlab::Regex.unbounded_semver_regex.).freeze end |
#semver_regex_message ⇒ Object
197 198 199 |
# File 'lib/gitlab/regex/packages.rb', line 197 def 'should follow SemVer: https://semver.org' end |
#sha256_regex ⇒ Object
274 275 276 |
# File 'lib/gitlab/regex/packages.rb', line 274 def sha256_regex @sha256_regex ||= /\A[0-9a-f]{64}\z/i end |
#slack_link_regex ⇒ Object
278 279 280 |
# File 'lib/gitlab/regex/packages.rb', line 278 def slack_link_regex @slack_link_regex ||= Gitlab::UntrustedRegexp.new('<([^|<>]*[|][^|<>]*)>') end |
#terraform_module_package_name_regex ⇒ Object
112 113 114 |
# File 'lib/gitlab/regex/packages.rb', line 112 def terraform_module_package_name_regex @terraform_module_package_name_regex ||= %r{\A[-a-z0-9]+\/[-a-z0-9]+\z} end |
#unbounded_semver_regex ⇒ Object
182 183 184 185 186 187 188 189 190 191 |
# File 'lib/gitlab/regex/packages.rb', line 182 def unbounded_semver_regex # See the official regex: https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string # The order of the alternatives in <prerelease> are intentionally # reordered to be greedy. Without this change, the unbounded regex would # only partially match "v0.0.0-20201230123456-abcdefabcdef". @unbounded_semver_regex ||= / #{_semver_major_minor_patch_regex}#{_semver_prerelease_build_regex} /x end |