Import pkg_install-20090425:
[netbsd-mini2440.git] / external / bsd / pkg_install / dist / admin / pkg_admin.1
blob839a243a78a700ead1ac42cad37854057b10c7ad
1 .\"     $NetBSD: pkg_admin.1,v 1.23 2009/04/25 21:31:13 joerg Exp $
2 .\"
3 .\" Copyright (c) 1999-2009 The NetBSD Foundation, Inc.
4 .\" All rights reserved.
5 .\"
6 .\" This code is derived from software contributed to The NetBSD Foundation
7 .\" by Hubert Feyrer <hubert@feyrer.de>.
8 .\"
9 .\" Redistribution and use in source and binary forms, with or without
10 .\" modification, are permitted provided that the following conditions
11 .\" are met:
12 .\" 1. Redistributions of source code must retain the above copyright
13 .\"    notice, this list of conditions and the following disclaimer.
14 .\" 2. Redistributions in binary form must reproduce the above copyright
15 .\"    notice, this list of conditions and the following disclaimer in the
16 .\"    documentation and/or other materials provided with the distribution.
17 .\" 3. All advertising materials mentioning features or use of this software
18 .\"    must display the following acknowledgement:
19 .\"        This product includes software developed by the NetBSD
20 .\"        Foundation, Inc. and its contributors.
21 .\" 4. Neither the name of The NetBSD Foundation nor the names of its
22 .\"    contributors may be used to endorse or promote products derived
23 .\"    from this software without specific prior written permission.
24 .\"
25 .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
26 .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27 .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28 .\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
29 .\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 .\" POSSIBILITY OF SUCH DAMAGE.
36 .\"
37 .Dd April 25, 2009
38 .Dt PKG_ADMIN 1
39 .Os
40 .Sh NAME
41 .Nm pkg_admin
42 .Nd perform various administrative tasks to the pkg system
43 .Sh SYNOPSIS
44 .Nm
45 .Op Fl bqSvV
46 .Op Fl C Ar config
47 .Op Fl d Ar lsdir
48 .Op Fl K Ar pkg_dbdir
49 .Op Fl s Ar sfx_pattern
50 .Ar command Op args ...
51 .Sh DESCRIPTION
52 This command performs various administrative tasks around the
53 .Nx
54 Packages System.
55 .Sh OPTIONS
56 The following command-line options are supported:
57 .Bl -tag -width indent
58 .It Fl b
59 Print only the base names when matching package names for
60 .Cm lsall
61 and
62 .Cm lsbest .
63 .It Fl C Ar config
64 Read the configuration file from
65 .Ar config
66 instead of the system default.
67 .It Fl d Ar lsdir
68 Set
69 .Ar lsdir
70 as the path to the directory in which to find matching package names for
71 .Cm lsall
72 and
73 .Cm lsbest .
74 .It Fl K Ar pkg_dbdir
75 Set
76 .Ar pkg_dbdir
77 as the package database directory.
78 If this option isn't specified, then the package database directory is
79 taken from the value of the environment variable
80 .Ev PKG_DBDIR
81 if it's set, otherwise it defaults to
82 .Pa /var/db/pkg .
83 .It Fl q
84 Perform checks in a quiet manner.
85 In normal operation,
86 .Nm
87 prints a
88 .Sq \&.
89 to standard output to indicate progress.
90 This option suppresses this progress indicator.
91 .It Fl S
92 Set the shell glob pattern for package suffixes when matching package
93 names for
94 .Cm lsall
95 and
96 .Cm lsbest
97 to be the null suffix.
98 .It Fl s Ar sfx_pattern
99 Set the shell glob pattern for package suffixes when matching package
100 names for
101 .Cm lsall
103 .Cm lsbest .
104 The default pattern is ".t[bg]z".
105 .It Fl V
106 Print version number and exit.
107 .It Fl v
108 Be more verbose.
111 The following commands are supported:
112 .Bl -tag -width indent
113 .It Cm add Ar pkg ...
114 For each listed package, write the absolute pathnames of the files listed in
116 .Pa +CONTENTS
117 file together with the package they belong to into the package database.
118 This should be used only by
119 .Xr pkg_view 1 .
120 .It Cm audit Oo Fl es Oc Oo Fl t Ar type Oc Oo Ar pkg Oc ...
121 Check the listed installed packages for vulnerabilities.
122 If no package is given, check all installed packages.
124 .Fl e
125 is given, also include end-of-life information.
127 .Fl s
128 is given, check the signature of the pkg-vulnerabilities file before using it.
129 .Fl t
130 restricts the reported vulnerabilities to type
131 .Ar type .
132 .It Cm audit-pkg Oo Fl es Oc Oo Fl t Ar type Oc Oo Ar pkg Oc ...
133 Like
134 .Cm audit ,
135 but check only the given package names or patterns.
136 .It Cm audit-batch Oo Fl es Oc Oo Fl t Ar type Oc Oo Ar pkg-list Oc ...
137 Like
138 .Cm audit-pkg ,
139 but read the package names or patterns one per line from the given files.
140 .It Cm audit-history Oo Fl s Oc Oo Fl t Ar type Oc Oo Ar pkgbase Oc ...
141 Print all vulnerabilities for the given base package names.
142 .It Cm check Op Ar pkg ...
143 Use this command to check the files belonging to some or all of the
144 packages installed on the local machine against the checksum
145 which was recorded in the
146 .Pa +CONTENTS
147 files at package installation time.
148 Symbolic links also have their integrity checked against the recorded
149 value at package installation time.
150 If no additional argument is given, the files of all installed packages
151 are checked, else only the named packages will be checked (wildcards can
152 be used here, see
153 .Xr pkg_info 1 ) .
155 The packages'
156 .Pa +CONTENTS
157 files will be parsed and the
158 checksum will be checked for every file found.
159 A warning message is printed if the expected checksum differs from the
160 checksum of the file on disk.
161 Symbolic links are also checked, ensuring that the targets on disk are
162 the same as the contents recorded at package installation time.
163 .It Cm check-license Ar condition
164 Check if
165 .Ar condition
166 can be fulfilled with the currently set of accepted licenses.
167 Prints either yes or no to stdout if the condition can be parsed,
168 otherwise it exits with error.
169 .It Cm check-pkg-vulnerabilities Oo Fl s Oc Ar file
170 Check format and hashes in the pkg-vulnerabilities file
171 .Ar file .
173 .Fl s
174 is given, also check the embedded signature.
175 .It Cm check-signature Ar file ...
176 Reports if
177 .Ar file
178 is a correctly signed package.
179 .It Cm check-single-license Ar liccense
180 Check if
181 .Ar license
182 is a valid license name and if it is in the set of acceptable licenses.
183 Prints either yes or no to stdout if the condition can be parsed,
184 otherwise it exits with error.
185 .It Cm config-var Ar variable
186 Print the current value of
187 .Ar variable
188 as used after parsing the configuration file.
189 .It Cm delete Ar pkg ...
190 For each listed package, remove all file entries in the package database that
191 belong to the package.
192 This should be used only by
193 .Xr pkg_view 1 .
194 .It Cm dump
195 Dump the contents of the package database, similar to
196 .Cm pkg_info -F .
197 Columns are printed for the key field used in the pkgdb - the filename -,
198 and the data field - the package the file belongs to.
199 .It Cm fetch-pkg-vulnerabilities Oo Fl su Oc
200 Fetch a new pkg-vulnerabilities file, check the format and if
201 .Fl s
202 is given the signature.
203 If all checks are passed, write it to pkgdb.
205 .Fl u
206 is given, the fetch is conditional and the file transfer is only done if
207 the remote version is newer than the one in pkgdb.
208 .It Cm lsall Ar /dir/pkgpattern
209 .It Cm lsbest Ar /dir/pkgpattern
210 List all/best package matching pattern in the given directory
211 .Pa /dir .
212 If the
213 .Fl d
214 flag is given, then that directory path overrides
215 .Pa /dir .
216 Can be used to work around limitations of /bin/sh and other
217 filename globbing mechanisms.
218 This option implements matching of
219 pkg-wildcards against arbitrary files and directories, useful mainly in
220 the build system itself.
222 .Xr pkg_info 1
223 for a description of the pattern.
225 Example:
226 .Bd -literal
227 yui# cd /usr/pkgsrc/packages/i386ELF/All/
228 yui# ls unzip*
229 unzip-5.40.tgz  unzip-5.41.tgz
230 yui# pkg_admin lsall 'unzip*'
231 /usr/pkgsrc/packages/i386ELF/All/unzip-5.40.tgz
232 /usr/pkgsrc/packages/i386ELF/All/unzip-5.41.tgz
233 yui# pkg_admin lsall 'unzip\*[Ge]5.40'
234 /usr/pkgsrc/packages/i386ELF/All/unzip-5.40.tgz
235 /usr/pkgsrc/packages/i386ELF/All/unzip-5.41.tgz
236 yui# pkg_admin lsall 'unzip\*[Ge]5.41'
237 /usr/pkgsrc/packages/i386ELF/All/unzip-5.41.tgz
238 yui# pkg_admin lsbest 'unzip\*[Ge]5.40'
239 /usr/pkgsrc/packages/i386ELF/All/unzip-5.41.tgz
240 yui# pkg_admin lsall /usr/pkgsrc/packages/i386ELF/All/'{mit,unproven}-pthread*'
241 /usr/pkgsrc/packages/i386ELF/All/mit-pthreads-1.60b6.tgz
242 /usr/pkgsrc/packages/i386ELF/All/unproven-pthreads-0.15.tgz
244 .It Cm pmatch Ar pattern Ar pkg
245 Returns true if
246 .Ar pkg
247 matches
248 .Ar pattern ,
249 otherwise returns false.
250 .It Cm rebuild
251 Rebuild the package database mapping from scratch, scanning
252 subdirectories in
253 .Pa /var/db/pkg
255 .Pa +CONTENTS
256 files, parsing them and writing the resulting absolute pathnames
257 together with the package they belong to into the package database.
259 This option is intended to be used for upgrading from non-pkgdb-pkg_*
260 tools to pkgdb-pkg_* tools, further manipulation of the pkgdb will be
261 done by
262 .Xr pkg_add 1 ,
263 .Xr pkg_delete 1 ,
265 .Xr pkg_create 1 .
267 Needs to be run as root.
268 .It Cm rebuild-tree
269 Rebuild the +REQUIRED_BY files from scratch by reresolving all dependencies.
271 This option is intended to be used for fixing inconsistencies between
272 the records of depending and depended-on packages, such as can arise
273 by the use of
274 .Cm pkg_delete -f .
275 .It Cm set Ar variable=value pkg ...
276 Set variable with information about the installed package.
278 .Cm unset
279 to remove a variable.
281 Packages that are not installed directly by the user but pulled in as
282 dependencies are marked by setting
283 .Dq automatic=YES .
284 .It Cm gpg-sign-package pkg
285 Sign the binary package
286 .Ar pkg
287 using GPG.
288 .It Cm x509-sign-package pkg spkg key cert
289 Sign the binary package
290 .Ar pkg
291 using the key
292 .Ar key
293 and the certificate
294 .Ar cert ,
295 using
296 .Ar spkg
297 as output file.
298 .It Cm unset Ar variable pkg ...
299 Remove an installation variable.
301 .Sh ENVIRONMENT
302 .Bl -tag -width indent -compact
303 .It Ev PKG_DBDIR
304 If the
305 .Fl K
306 flag isn't given, then
307 .Ev PKG_DBDIR
308 is the location of the package database directory.
309 The default package database directory is
310 .Pa /var/db/pkg .
312 .Sh CONFIGURATION VARIABLES
313 The following variables change the behavior of
315 and are described in
316 .Xr pkg_install.conf 5 :
317 .Bl -tag -width CERTIFICATE_ANCHOR_PKGS
318 .It Ev CERTIFICATE_ANCHOR_PKGS
319 .It Ev CERTIFICATE_ANCHOR_PKGVULN
320 .It Ev CERTIFICATE_CHAIN
321 .It Ev GPG
322 .It Ev PKGVULNDIR
323 .It Ev PKGVULNURL
324 .It Ev IGNORE_URL
326 .Sh FILES
327 .Bl -tag -width /var/db/pkg/pkgdb.byfile.db -compact
328 .It Pa /var/db/pkg/pkgdb.byfile.db
329 .It Pa /var/db/pkg/\*[Lt]pkg\*[Gt]/+CONTENTS
331 .Sh SEE ALSO
332 .Xr pkg_add 1 ,
333 .Xr pkg_create 1 ,
334 .Xr pkg_delete 1 ,
335 .Xr pkg_info 1 ,
336 .Xr pkg_view 1 ,
337 .Xr pkg_install.conf 5 ,
338 .Xr pkgsrc 7
339 .Sh HISTORY
342 command first appeared in
343 .Nx 1.4 .
344 .Sh AUTHORS
347 command was written by Hubert Feyrer.