Class: Homebrew::Livecheck::Strategy::Npm

Inherits:
Object
  • Object
show all
Defined in:
brew/Library/Homebrew/livecheck/strategy/npm.rb

Overview

The npm strategy identifies versions of software at registry.npmjs.org by checking the listed versions for a package.

npm URLs take one of the following formats: * https://registry.npmjs.org/example/-/example-1.2.3.tgz * https://registry.npmjs.org/@example/example/-/example-1.2.3.tgz

The default regex matches URLs in the href attributes of version tags on the “Versions” tab of the package page.

Constant Summary collapse

NICE_NAME =
"npm"
URL_MATCH_REGEX =

The Regexp used to determine if the strategy applies to the URL.

/registry\.npmjs\.org/i.freeze

Class Method Summary collapse

Class Method Details

.find_versions(url, regex = nil) ⇒ Hash

Generates a URL and regex (if one isn’t provided) and passes them to the PageMatch#find_versions method to identify versions in the content.

Parameters:

  • url (String)

    the URL of the content to check

  • regex (Regexp) (defaults to: nil)

    a regex used for matching versions in content

Returns:

  • (Hash)


36
37
38
39
40
41
42
43
44
45
46
47
# File 'brew/Library/Homebrew/livecheck/strategy/npm.rb', line 36

def self.find_versions(url, regex = nil)
  %r{registry\.npmjs\.org/(?<package_name>.+)/-/}i =~ url

  page_url = "https://www.npmjs.com/package/#{package_name}?activeTab=versions"

  # Example regexes:
  # * `%r{href=.*?/package/example/v/(\d+(?:\.\d+)+)"}i`
  # * `%r{href=.*?/package/@example/example/v/(\d+(?:\.\d+)+)"}i`
  regex ||= %r{href=.*?/package/#{Regexp.escape(package_name)}/v/(\d+(?:\.\d+)+)"}i

  Homebrew::Livecheck::Strategy::PageMatch.find_versions(page_url, regex)
end

.match?(url) ⇒ Boolean

Whether the strategy can be applied to the provided URL.

Parameters:

  • url (String)

    the URL to match against

Returns:

  • (Boolean)


26
27
28
# File 'brew/Library/Homebrew/livecheck/strategy/npm.rb', line 26

def self.match?(url)
  URL_MATCH_REGEX.match?(url)
end