-
Notifications
You must be signed in to change notification settings - Fork 44
/
Copy pathdoc.go
114 lines (79 loc) · 3.14 KB
/
doc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
Package rpm implements the rpm package file format.
package main
import (
"fmt"
"log"
"github.com/cavaliergopher/rpm"
)
func main() {
pkg, err := rpm.Open("golang-1.17.2-1.el7.x86_64.rpm")
if err != nil {
log.Fatal(err)
}
fmt.Println("Package:", pkg)
fmt.Println("Summary:", pkg.Summary())
// Output:
// Package: golang-1.17.2-1.el7.x86_64
// Summary: The Go Programming Language
}
For more information about the rpm file format, see:
http://ftp.rpm.org/max-rpm/s1-rpm-file-format-rpm-file-format.html
Packages are composed of two headers: the Signature header and the "Header"
header. Each contains key-value pairs called tags. Tags map an integer key to a
value whose data type will be one of the TagType types. Tag values can be
decoded with the appropriate Tag method for the data type.
Many known tags are available as Package methods. For example, RPMTAG_NAME and
RPMTAG_BUILDTIME are available as Package.Name and Package.BuildTime
respectively.
fmt.Println(pkg.Name(), pkg.BuildTime())
Tags can be retrieved and decoded from the Signature or Header headers directly
using Header.GetTag and their tag identifier.
const (
RPMTagName = 1000
RPMTagBuidlTime = 1006
)
fmt.Println(
pkg.Header.GetTag(RPMTagName).String()),
time.Unix(pkg.Header.GetTag(RPMTagBuildTime).Int64(), 0),
)
Header.GetTag and all Tag methods will return a zero value if the header or the
tag do not exist, or if the tag has a different data type.
You may enumerate all tags in a header with Header.Tags:
for id, tag := range pkg.Header.Tags {
fmt.Println(id, tag.Type, tag.Value)
}
Comparing versions
In the rpm ecosystem, package versions are compared using EVR; epoch, version,
release. Versions may be compared using the Compare function.
if rpm.Compare(pkgA, pkgB) == 1 {
fmt.Println("A is more recent than B")
}
Packages may be be sorted using the PackageSlice type which implements
sort.Interface. Packages are sorted lexically by name ascending and then by
version descending. Version is evaluated first by epoch, then by version string,
then by release.
sort.Sort(PackageSlice(pkgs))
The Sort function is provided for your convenience.
rpm.Sort(pkgs)
Checksum validation
Packages may be validated using MD5Check or GPGCheck. See the example for each
function.
Extracting files
The payload of an rpm package is typically archived in cpio format and
compressed with xz. To decompress and unarchive an rpm payload, the reader that
read the rpm package headers will be positioned at the beginning of the payload
and can be reused with the appropriate Go packages for the rpm payload format.
You can check the archive format with Package.PayloadFormat and the compression
algorithm with Package.PayloadCompression.
For the cpio archive format, the following package is recommended:
https://github.com/cavaliergopher/cpio
For xz compression, the following package is recommended:
https://github.com/ulikunitz/xz
See README.md for a working example of extracting files from a cpio/xz rpm
package using these packages.
Example programs
See cmd/rpmdump and cmd/rpminfo for example programs that emulate tools from the
rpm ecosystem.
*/
package rpm