Class: Y2Packager::Package

Inherits:
Object
  • Object
show all
Includes:
Yast::Logger
Defined in:
library/packages/src/lib/y2packager/package.rb

Overview

This class represents a libzypp package and it offers an API to common operations.

The idea is extending this class with new methods when needed.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name, repo_id, version) ⇒ Package

Constructor

Parameters:

  • name (String)

    Package name

  • repo_id (Integer)

    Repository ID

  • version (String)

    Package version



73
74
75
76
77
# File 'library/packages/src/lib/y2packager/package.rb', line 73

def initialize(name, repo_id, version)
  @name = name
  @repo_id = repo_id
  @version = version
end

Instance Attribute Details

#nameString (readonly)

Returns Package name.

Returns:

  • (String)

    Package name



30
31
32
# File 'library/packages/src/lib/y2packager/package.rb', line 30

def name
  @name
end

#repo_idInteger (readonly)

Returns Id of the repository where the package lives.

Returns:

  • (Integer)

    Id of the repository where the package lives



32
33
34
# File 'library/packages/src/lib/y2packager/package.rb', line 32

def repo_id
  @repo_id
end

#versionString (readonly)

Returns Package version.

Returns:

  • (String)

    Package version



34
35
36
# File 'library/packages/src/lib/y2packager/package.rb', line 34

def version
  @version
end

Class Method Details

.find(name) ⇒ Array<Package>?

Find packages by name

Parameters:

  • name (String)

    Package name

Returns:

  • (Array<Package>, nil)

    Packages named like name. It returns nil if some problem occurs interacting with libzypp.



42
43
44
45
46
47
48
49
# File 'library/packages/src/lib/y2packager/package.rb', line 42

def find(name)
  resolvables = Yast::Pkg.Resolvables({ kind: :package, name: name },
    [:name, :source, :version])

  return nil if resolvables.nil?

  resolvables.map { |i| new(i["name"], i["source"], i["version"]) }
end

.last_version(name, statuses: [:available, :selected]) ⇒ Y2Packager::Package?

Find the highest version of requested package with given statuses

Parameters:

  • name (String)

    name of searched package

  • statuses (Array<Symbol>) (defaults to: [:available, :selected])

    allowed package statuses

Returns:



57
58
59
60
61
62
63
64
65
# File 'library/packages/src/lib/y2packager/package.rb', line 57

def last_version(name, statuses: [:available, :selected])
  packages = find(name)

  return nil unless packages

  packages
    .select { |i| statuses.include?(i.status) }
    .max { |a, b| Yast::Pkg.CompareVersions(a.version, b.version) }
end

Instance Method Details

#download_to(path) ⇒ Object

Download a package to the given path

Parameters:

  • path (String, Pathname)

    Path to download the package to

Raises:

  • PackageFetchError

See Also:



106
107
108
109
# File 'library/packages/src/lib/y2packager/package.rb', line 106

def download_to(path)
  downloader = Packages::PackageDownloader.new(repo_id, name)
  downloader.download(path.to_s)
end

#extract_to(directory) ⇒ Object

Download and extract the package to the given directory

Parameters:

  • directory (String, Pathname)

    Path to extract the package to

Raises:

  • PackageFetchError

  • PackageExtractionError

See Also:



117
118
119
120
121
122
123
124
125
# File 'library/packages/src/lib/y2packager/package.rb', line 117

def extract_to(directory)
  tmpfile = Tempfile.new("downloaded-package-#{name}-")
  download_to(tmpfile.path)
  extractor = Packages::PackageExtractor.new(tmpfile.path)
  extractor.extract(directory.to_s)
ensure
  tmpfile.close
  tmpfile.unlink
end

#statusSymbol

Return package status

Ask libzypp about package status.

Returns:

  • (Symbol)

    Package status (:installed, :available, etc.)

See Also:

  • Yast::Pkg.Resolvables


85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# File 'library/packages/src/lib/y2packager/package.rb', line 85

def status
  resolvables = Yast::Pkg.Resolvables({ kind: :package, name: name,
    version: version, source: repo_id }, [:status])

  log.warn "Found multiple resolvables: #{resolvables}" if resolvables.size > 1

  resolvable = resolvables.first

  if !resolvable
    log.warn "Resolvable not found: #{name}-#{version} from repo #{repo_id}"
    return nil
  end

  resolvable["status"]
end