4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright (c) 2017 Peter Tribble.
27 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
28 * Use is subject to license terms.
31 /* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
32 /* All Rights Reserved */
42 #include <sys/types.h>
50 * The contents database file interface.
53 typedef struct pkg_server
*PKGserver
;
55 /* Some commands modify the internal database: add them here */
56 #define PKG_WRITE_COMMAND(cmd) ((cmd) == PKG_ADDLINES)
59 #define PKG_FINDFILE 0x1
61 #define PKG_PKGSYNC 0x3
62 #define PKG_FILTER 0x4
63 #define PKG_ADDLINES 0x5
66 #define SUNW_PKG_SERVERMODE "SUNW_PKG_SERVERMODE"
68 #define PKGSERV_MODE "pkg-server-mode="
69 #define PKGSERV_MODE_LEN (sizeof (PKGSERV_MODE) - 1)
71 #define MODE_PERMANENT "permanent"
72 #define MODE_RUN_ONCE "run_once"
73 #define MODE_TIMEOUT "timeout"
75 #define MAXLOGFILESIZE (20 * 1024 * 1024)
77 #define PKGLOG "pkglog"
78 #define PKGDOOR ".door"
81 INVALID
, /* Not initialized */
82 NEVER
, /* Don't start, does check if it is running. */
83 FLUSH_LOG
, /* Run it once to incorporate the log. */
84 RUN_ONCE
, /* Run until the current client stops. */
85 TIMEOUT
, /* Run until a timeout occurs. */
86 PERMANENT
, /* Run until it is externally terminated. */
87 DEFAULTMODE
= TIMEOUT
/* The default mode, must come last */
90 typedef struct pkgcmd
{
95 typedef struct pkgfilter
{
102 * Virtual File Protocol definitions
106 * flags associated with virtual file protocol operations; note that these flags
107 * may only occupy the low order 16 bits of the 32-bit unsigned flag.
110 typedef unsigned long VFPFLAGS_T
;
112 #define VFP_NONE 0x00000000 /* no special flags */
113 #define VFP_NEEDNOW 0x00000001 /* need memory now */
114 #define VFP_SEQUENTIAL 0x00000002 /* sequential access */
115 #define VFP_RANDOM 0x00000004 /* random access */
116 #define VFP_NOMMAP 0x00000008 /* do not use mmap to access file */
117 #define VFP_NOMALLOC 0x00000010 /* do not use malloc to buffer file */
119 /* virtual file protocol object */
121 typedef struct _vfp VFP_T
;
123 /* structure behind the virtual file protocol object */
126 FILE *_vfpFile
; /* -> opened FILE */
127 char *_vfpCurr
; /* -> current byte to read/write */
128 char *_vfpHighWater
; /* -> last byte modified */
129 char *_vfpEnd
; /* -> last data byte */
130 char *_vfpPath
; /* -> path associated with FILE */
131 char *_vfpStart
; /* -> first data byte */
132 void *_vfpExtra
; /* undefined */
133 size_t _vfpSize
; /* size of mapped/allocated area */
134 size_t _vfpMapSize
; /* # mapped bytes */
135 VFPFLAGS_T _vfpFlags
; /* flags associated with vfp/data */
136 int _vfpOverflow
; /* non-zero if buffer write overflow */
137 blkcnt_t _vfpCkStBlocks
; /* checkpoint # blocks */
138 dev_t _vfpCkDev
; /* checkpoint device i.d. */
139 ino_t _vfpCkIno
; /* checkpoint inode # */
140 off_t _vfpCkSize
; /* checkpoint size */
141 time_t _vfpCkMtime
; /* checkpoint modification time */
145 * get highest modified byte (length) contained in vfp
147 * determine number of bytes to write - it will be the highest of:
148 * -- the current pointer into the file - this is updated whenever
149 * the location of the file is changed by a single byte
150 * -- the last "high water mark" - the last known location that
151 * was written to the file - updated only when the location
152 * of the file is directly changed - e.g. vfpSetCurrCharPtr,
153 * vfpTruncate, vfpRewind.
154 * this reduces the "bookkeeping" that needs to be done to know
155 * how many bytes to write out to the file - typically a file is
156 * written sequentially so the current file pointer is sufficient
157 * to determine how many bytes to write out.
160 #define vfpGetModifiedLen(VFP) \
161 (size_t)(((VFP)->_vfpHighWater > (VFP)->_vfpCurr) ? \
162 (((ptrdiff_t)(VFP)->_vfpHighWater - \
163 (ptrdiff_t)(VFP)->_vfpStart)) : \
164 (((ptrdiff_t)(VFP)->_vfpCurr - \
165 (ptrdiff_t)(VFP)->_vfpStart)))
168 * increment current pointer by specified delta
169 * if the delta exceeds the buffer size, set pointer to buffer end
171 #define vfpIncCurrPtrBy(VFP, INC) \
173 ((VFP)->_vfpCurr) += (INC); \
174 if (((VFP)->_vfpCurr) > ((VFP)->_vfpEnd)) { \
175 (VFP)->_vfpCurr = (VFP)->_vfpEnd; \
176 (VFP)->_vfpOverflow = 1; \
178 if ((VFP)->_vfpHighWater < (VFP)->_vfpCurr) { \
179 (VFP)->_vfpHighWater = (VFP)->_vfpCurr; \
183 /* get the path associated with the vfp */
184 #define vfpGetPath(VFP) ((VFP)->_vfpPath)
186 /* get a string from the vfp into a fixed size buffer */
187 #define vfpGets(VFP, PTR, LEN) \
189 char *XXpXX = (PTR); \
190 size_t XXlXX = (LEN); \
191 while ((*(VFP)->_vfpCurr != '\0') && \
192 (*(VFP)->_vfpCurr != '\n')) { \
194 *XXpXX++ = *(VFP)->_vfpCurr; \
200 if (*(VFP)->_vfpCurr != '\0') { \
205 /* get number of bytes remaining to read */
206 #define vfpGetBytesRemaining(VFP) \
207 (((((VFP)->_vfpHighWater) <= ((VFP)->_vfpCurr))) ? 0 : \
208 ((((ptrdiff_t)(VFP)->_vfpHighWater)-((ptrdiff_t)(VFP)->_vfpCurr))))
210 /* get number of bytes remaining to write */
211 #define vfpGetBytesAvailable(VFP) \
212 (((((VFP)->_vfpEnd) <= ((VFP)->_vfpCurr))) ? 0 : \
213 ((((ptrdiff_t)(VFP)->_vfpEnd)-((ptrdiff_t)(VFP)->_vfpCurr))))
215 /* put current character and increment to next */
216 #define vfpPutc(VFP, C) \
218 (*(VFP)->_vfpCurr) = ((char)(C)); \
219 vfpIncCurrPtrBy((VFP), 1); \
222 /* put integer to current character and increment */
223 #define vfpPutInteger(VFP, NUMBER) vfpPutFormat((VFP), "%d", (NUMBER))
225 /* put long to current character and increment */
226 #define vfpPutLong(VFP, NUMBER) vfpPutFormat((VFP), "%ld", (NUMBER))
228 /* get current character and increment to next */
229 #define vfpGetc(VFP) (*(VFP)->_vfpCurr++)
231 /* get current character - do not increment */
232 #define vfpGetcNoInc(VFP) (*(VFP)->_vfpCurr)
234 /* get pointer to current character */
235 #define vfpGetCurrCharPtr(VFP) ((VFP)->_vfpCurr)
237 /* increment current character pointer */
238 #define vfpIncCurrPtr(VFP) vfpIncCurrPtrBy((VFP), 1)
240 /* decrement current character pointer */
241 #define vfpDecCurrPtr(VFP) ((VFP)->_vfpCurr--)
243 /* get pointer to first data byte in buffer */
244 #define vfpGetFirstCharPtr(VFP) ((VFP)->_vfpStart)
246 /* get pointer to last data byte in buffer */
247 #define vfpGetLastCharPtr(VFP) ((VFP)->_vfpHighWater)
249 /* set pointer to current character */
250 #define vfpSetCurrCharPtr(VFP, PTR) \
251 if ((VFP)->_vfpCurr > (VFP)->_vfpHighWater) { \
252 (VFP)->_vfpHighWater = (VFP)->_vfpCurr; \
254 ((VFP)->_vfpCurr = (PTR))
256 /* set pointer to last data byte in buffer */
257 #define vfpSetLastCharPtr(VFP, PTR) \
258 if ((PTR) >= (VFP)->_vfpStart) { \
259 (VFP)->_vfpHighWater = (PTR); \
260 if ((VFP)->_vfpCurr > (VFP)->_vfpHighWater) { \
261 (VFP)->_vfpCurr = (VFP)->_vfpHighWater; \
265 /* seek to end of file - one past last data byte in file */
266 #define vfpSeekToEnd(VFP) ((VFP)->_vfpCurr = ((VFP)->_vfpHighWater)+1)
268 /* get number of bytes between current char and specified char */
269 #define vfpGetCurrPtrDelta(VFP, P) \
270 (((ptrdiff_t)(P))-((ptrdiff_t)(VFP)->_vfpCurr))
272 /* put string to current character and increment */
273 #define vfpPuts(VFP, S) \
277 xxLen = vfpGetBytesAvailable((VFP)); \
278 xxResult = strlcpy(((VFP)->_vfpCurr), (S), xxLen); \
279 vfpIncCurrPtrBy((VFP), xxResult); \
282 /* put fixed number of bytes to current character and increment */
283 #define vfpPutBytes(VFP, PTR, LEN) \
286 xxLen = vfpGetBytesAvailable((VFP)); \
287 if (xxLen > (LEN)) { \
290 (VFP)->_vfpOverflow = 1; \
292 memcpy((VFP)->_vfpCurr, (PTR), (xxLen)); \
293 vfpIncCurrPtrBy((VFP), (xxLen)); \
296 /* put format one arg to current character and increment */
297 #define vfpPutFormat(VFP, FORMAT, ARG) \
299 char xxTeMpXX[256]; \
300 (void) snprintf(xxTeMpXX, sizeof (xxTeMpXX), (FORMAT), (ARG)); \
301 vfpPuts((VFP), xxTeMpXX); \
305 char *text_buffer
; /* start of allocated buffer */
306 int offset
; /* number of bytes into the text_buffer */
307 int allocation
; /* size of buffer in bytes */
310 /* This structure is used to hold a dynamically growing string */
318 /* setmapmode() defines */
319 #define MAPALL 0 /* resolve all variables */
320 #define MAPBUILD 1 /* map only build variables */
321 #define MAPINSTALL 2 /* map only install variables */
322 #define MAPNONE 3 /* map no variables */
324 #define NON_ABI_NAMELNGTH 33 /* 32 chars for name + 1 for NULL */
326 #define BLK_SIZE 512 /* size of logical block */
328 /* max length for printed attributes */
332 * These three defines indicate that the prototype file contains a '?'
333 * meaning do not specify this data in the pkgmap entry.
335 #define CURMODE BADMODE /* current mode has been specified */
336 #define CUROWNER BADOWNER /* ... same for owner ... */
337 #define CURGROUP BADGROUP /* ... and group. */
339 #define WILDCARD BADMODE >> 1
340 #define DB_UNDEFINED_ENTRY "?"
342 #define DEFAULT_MODE 0755
343 #define DEFAULT_MODE_FILE 0644
344 #define DEFAULT_OWNER "root"
345 #define DEFAULT_GROUP "other"
347 #define INST_RELEASE "var/sadm/system/admin/INST_RELEASE"
349 #define RANDOM "/dev/urandom"
352 #define TERM_WIDTH 60
353 #define SMALL_DIVISOR 4
354 #define MED_DIVISOR 5
355 #define LARGE_DIVISOR 10
357 #define PKGADD "pkgadd"
359 /* package header magic tokens */
360 #define HDR_PREFIX "# PaCkAgE DaTaStReAm"
361 #define HDR_SUFFIX "# end of header"
363 #define GROUP "/etc/group"
364 #define PASSWD "/etc/passwd"
367 * The next three mean that no mode, owner or group was specified or that the
368 * one specified is invalid for some reason. Sometimes this is an error in
369 * which case it is generally converted to CUR* with a warning. Other times
370 * it means "look it up" by stating the existing file system object pointred
371 * to in the prototype file.
373 #define NOMODE (BADMODE-1)
377 /* string comparitor abbreviators */
379 #define ci_streq(a, b) (strcasecmp((a), (b)) == 0)
380 #define ci_strneq(a, b, c) (strncasecmp((a), (b), (c)) == 0)
381 #define streq(a, b) (strcmp((a), (b)) == 0)
382 #define strneq(a, b, c) (strncmp((a), (b), (c)) == 0)
384 extern FILE *epopen(char *cmd
, char *mode
);
385 extern char **gpkglist(char *dir
, char **pkg
, char **catg
);
386 extern int is_not_valid_length(char **category
);
387 extern int is_not_valid_category(char **category
, char *progname
);
388 extern int is_same_CATEGORY(char **category
, char *installed_category
);
389 extern char **get_categories(char *catg_arg
);
391 extern void pkglist_cont(char *keyword
);
392 extern char **pkgalias(char *pkg
);
393 extern char *get_prog_name(void);
394 extern char *set_prog_name(char *name
);
395 extern int averify(int fix
, char *ftype
, char *path
, struct ainfo
*ainfo
);
396 extern int ckparam(char *param
, char *value
);
397 extern int ckvolseq(char *dir
, int part
, int nparts
);
398 extern int cverify(int fix
, char *ftype
, char *path
, struct cinfo
*cinfo
,
400 extern unsigned long compute_checksum(int *r_cksumerr
, char *a_path
);
401 extern int fverify(int fix
, char *ftype
, char *path
, struct ainfo
*ainfo
,
402 struct cinfo
*cinfo
);
403 extern char *getErrbufAddr(void);
404 extern int getErrbufSize(void);
405 extern char *getErrstr(void);
406 extern void setErrstr(char *errstr
);
407 extern int devtype(char *alias
, struct pkgdev
*devp
);
408 extern int ds_totread
; /* total number of parts read */
409 extern int ds_close(int pkgendflg
);
410 extern int ds_findpkg(char *device
, char *pkg
);
411 extern int ds_getinfo(char *string
);
412 extern int ds_getpkg(char *device
, int n
, char *dstdir
);
413 extern int ds_ginit(char *device
);
414 extern boolean_t
ds_fd_open(void);
415 extern int ds_init(char *device
, char **pkg
, char *norewind
);
416 extern int ds_next(char *, char *);
417 extern int ds_readbuf(char *device
);
418 extern int epclose(FILE *pp
);
419 extern int esystem(char *cmd
, int ifd
, int ofd
);
420 extern int e_ExecCmdArray(int *r_status
, char **r_results
,
421 char *a_inputFile
, char *a_cmd
, char **a_args
);
422 extern int e_ExecCmdList(int *r_status
, char **r_results
,
423 char *a_inputFile
, char *a_cmd
, ...);
424 extern int gpkgmap(struct cfent
*ept
, FILE *fp
);
425 extern int gpkgmapvfp(struct cfent
*ept
, VFP_T
*fpv
);
426 extern void setmapmode(int mode_no
);
427 extern int isFdRemote(int a_fd
);
428 extern int isFstypeRemote(char *a_fstype
);
429 extern int isPathRemote(char *a_path
);
430 extern int iscpio(char *path
, int *iscomp
);
431 extern int isdir(char *path
);
432 extern int isfile(char *dir
, char *file
);
433 extern int fmkdir(char *a_path
, int a_mode
);
434 extern int pkgexecl(char *filein
, char *fileout
, char *uname
, char *gname
,
436 extern int pkgexecv(char *filein
, char *fileout
, char *uname
, char *gname
,
438 extern int pkghead(char *device
);
439 extern int pkgmount(struct pkgdev
*devp
, char *pkg
, int part
, int nparts
,
441 extern int pkgtrans(char *device1
, char *device2
, char **pkg
,
443 extern int pkgumount(struct pkgdev
*devp
);
444 extern int ppkgmap(struct cfent
*ept
, FILE *fp
);
445 extern int putcfile(struct cfent
*ept
, FILE *fp
);
446 extern int putcvfpfile(struct cfent
*ept
, VFP_T
*vfp
);
447 extern int rrmdir(char *path
);
448 extern void set_memalloc_failure_func(void (*)(int));
449 extern void *xmalloc(size_t size
);
450 extern void *xrealloc(void *ptr
, size_t size
);
451 extern char *xstrdup(char *str
);
453 extern int srchcfile(struct cfent
*ept
, char *path
, PKGserver server
);
454 extern struct group
*cgrgid(gid_t gid
);
455 extern struct group
*cgrnam(char *nam
);
456 extern struct passwd
*cpwnam(char *nam
);
457 extern struct passwd
*cpwuid(uid_t uid
);
458 extern struct group
*clgrgid(gid_t gid
);
459 extern struct group
*clgrnam(char *nam
);
460 extern struct passwd
*clpwnam(char *nam
);
461 extern struct passwd
*clpwuid(uid_t uid
);
462 extern void basepath(char *path
, char *basedir
, char *ir
);
463 extern void canonize(char *file
);
464 extern void canonize_slashes(char *file
);
465 extern void checksum_off(void);
466 extern void checksum_on(void);
467 extern void cvtpath(char *path
, char *copy
);
468 extern void ds_order(char *list
[]);
469 extern void ds_putinfo(char *buf
, size_t);
470 extern void ds_skiptoend(char *device
);
471 extern void ecleanup(void);
473 extern void logerr(char *fmt
, ...);
474 extern int mappath(int flag
, char *path
);
475 extern int mapvar(int flag
, char *varname
);
477 extern void progerr(char *fmt
, ...);
478 extern void rpterr(void);
479 extern void tputcfent(struct cfent
*ept
, FILE *fp
);
480 extern void set_nonABI_symlinks(void);
481 extern int nonABI_symlinks(void);
482 extern void disable_attribute_check(void);
483 extern int get_disable_attribute_check(void);
486 void pkgstrConvertUllToTimeString_r(unsigned long long a_time
,
487 char *a_buf
, int a_bufLen
);
488 char *pkgstrConvertPathToBasename(char *a_path
);
489 char *pkgstrConvertPathToDirname(char *a_path
);
490 char *pkgstrDup(char *a_str
);
491 char *pkgstrLocatePathBasename(char *a_path
);
492 void pkgstrScaleNumericString(char *a_buf
, unsigned long long scale
);
493 void pkgstrAddToken(char **a_old
, char *a_new
, char a_separator
);
494 boolean_t
pkgstrContainsToken(char *a_string
, char *a_token
,
496 void pkgstrExpandTokens(char **a_old
, char *a_string
,
497 char a_separator
, char *a_separators
);
498 char *pkgstrGetToken(char *r_sep
, char *a_string
, int a_index
,
500 void pkgstrGetToken_r(char *r_sep
, char *a_string
, int a_index
,
501 char *a_separators
, char *a_buf
, int a_bufLen
);
502 unsigned long pkgstrNumTokens(char *a_string
, char *a_separators
);
503 char *pkgstrPrintf(char *a_format
, ...);
504 void pkgstrPrintf_r(char *a_buf
, int a_bufLen
, char *a_format
, ...);
505 void pkgstrRemoveToken(char **r_string
, char *a_token
,
506 char *a_separators
, int a_index
);
507 void pkgstrRemoveLeadingWhitespace(char **a_str
);
509 extern int vfpCheckpointFile(VFP_T
**r_destVfp
, VFP_T
**a_vfp
,
511 extern int vfpCheckpointOpen(VFP_T
**a_cvfp
, VFP_T
**r_vfp
, char *a_path
,
512 char *a_mode
, VFPFLAGS_T a_flags
);
513 extern int vfpClearModified(VFP_T
*a_vfp
);
514 extern int vfpClose(VFP_T
**r_vfp
);
515 extern int vfpGetModified(VFP_T
*a_vfp
);
516 extern int vfpOpen(VFP_T
**r_vfp
, char *a_path
, char *a_mode
,
518 extern void vfpRewind(VFP_T
*a_vfp
);
519 extern ssize_t
vfpSafePwrite(int a_fildes
, void *a_buf
,
520 size_t a_nbyte
, off_t a_offset
);
521 extern ssize_t
vfpSafeWrite(int a_fildes
, void *a_buf
, size_t a_nbyte
);
522 extern int vfpSetFlags(VFP_T
*a_vfp
, VFPFLAGS_T a_flags
);
523 extern int vfpSetModified(VFP_T
*a_vfp
);
524 extern int vfpSetSize(VFP_T
*a_vfp
, size_t a_size
);
525 extern void vfpTruncate(VFP_T
*a_vfp
);
526 extern int vfpWriteToFile(VFP_T
*a_vfp
, char *a_path
);
528 /* handlelocalfs.c */
529 boolean_t
enable_local_fs(void);
530 boolean_t
restore_local_fs(void);
533 extern boolean_t
path_valid(char *);
536 extern PKGserver
pkgopenserver(const char *, const char *, boolean_t
);
537 extern void pkgcloseserver(PKGserver
);
538 extern int pkgcmd(PKGserver
, void *, size_t, char **, size_t *,
540 extern boolean_t
pkgsync_needed(const char *, const char *, boolean_t
);
541 extern int pkgsync(const char *, const char *, boolean_t
);
542 extern int pkgservercommitfile(VFP_T
*, PKGserver
);
543 extern int pkgopenfilter(PKGserver server
, const char *pkginst
);
544 extern void pkgclosefilter(PKGserver
);
545 extern char *pkggetentry(PKGserver
, int *, int *);
546 extern char *pkggetentry_named(PKGserver
, const char *, int *,
548 extern void pkgserversetmode(start_mode_t
);
549 extern start_mode_t
pkgservergetmode(void);
550 extern start_mode_t
pkgparsemode(const char *);
551 extern char *pkgmodeargument(start_mode_t
);
557 #endif /* _PKGLIB_H */