1996-01-01 08:27:41 +00:00
|
|
|
/*
|
2000-01-26 07:17:00 +00:00
|
|
|
* Copyright (c) 1996 Peter Wemm <peter@FreeBSD.org>.
|
1996-01-01 08:27:41 +00:00
|
|
|
* All rights reserved.
|
2002-05-08 00:50:07 +00:00
|
|
|
* Copyright (c) 2002 Networks Associates Technology, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Portions of this software were developed for the FreeBSD Project by
|
|
|
|
* ThinkSec AS and NAI Labs, the Security Research Division of Network
|
|
|
|
* Associates, Inc. under DARPA/SPAWAR contract N66001-01-C-8035
|
|
|
|
* ("CBOSS"), as part of the DARPA CHATS research program.
|
1996-01-01 08:27:41 +00:00
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, is permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
2000-01-26 07:17:00 +00:00
|
|
|
* notice, this list of conditions and the following disclaimer.
|
1996-01-01 08:27:41 +00:00
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
2002-05-08 00:50:07 +00:00
|
|
|
* 3. The name of the author may not be used to endorse or promote
|
|
|
|
* products derived from this software without specific prior written
|
|
|
|
* permission.
|
2000-01-26 07:17:00 +00:00
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
1996-01-01 08:27:41 +00:00
|
|
|
*
|
1999-08-28 00:22:10 +00:00
|
|
|
* $FreeBSD$
|
1996-01-01 08:27:41 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LIBUTIL_H_
|
|
|
|
#define _LIBUTIL_H_
|
|
|
|
|
2009-12-02 15:56:18 +00:00
|
|
|
#include <sys/cdefs.h>
|
|
|
|
#include <sys/_types.h>
|
2011-05-05 14:45:24 +00:00
|
|
|
#include <sys/_stdint.h>
|
2009-12-02 15:56:18 +00:00
|
|
|
|
|
|
|
#ifndef _GID_T_DECLARED
|
|
|
|
typedef __gid_t gid_t;
|
|
|
|
#define _GID_T_DECLARED
|
|
|
|
#endif
|
|
|
|
|
2012-01-12 22:49:36 +00:00
|
|
|
#ifndef _MODE_T_DECLARED
|
2012-01-16 21:19:23 +00:00
|
|
|
typedef __mode_t mode_t;
|
|
|
|
#define _MODE_T_DECLARED
|
2012-01-12 22:49:36 +00:00
|
|
|
#endif
|
|
|
|
|
2009-12-02 15:56:18 +00:00
|
|
|
#ifndef _PID_T_DECLARED
|
|
|
|
typedef __pid_t pid_t;
|
|
|
|
#define _PID_T_DECLARED
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _SIZE_T_DECLARED
|
|
|
|
typedef __size_t size_t;
|
|
|
|
#define _SIZE_T_DECLARED
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _UID_T_DECLARED
|
|
|
|
typedef __uid_t uid_t;
|
|
|
|
#define _UID_T_DECLARED
|
|
|
|
#endif
|
|
|
|
|
2012-01-16 21:19:23 +00:00
|
|
|
#define PROPERTY_MAX_NAME 64
|
|
|
|
#define PROPERTY_MAX_VALUE 512
|
2000-11-08 11:57:03 +00:00
|
|
|
|
2012-01-26 20:35:01 +00:00
|
|
|
/* For properties.c. */
|
1998-10-07 17:32:49 +00:00
|
|
|
typedef struct _property {
|
|
|
|
struct _property *next;
|
2012-01-12 14:40:25 +00:00
|
|
|
char *name;
|
|
|
|
char *value;
|
1998-10-07 17:32:49 +00:00
|
|
|
} *properties;
|
|
|
|
|
2012-01-26 20:35:01 +00:00
|
|
|
/* Avoid pulling in all the include files for no need. */
|
1999-04-06 23:02:35 +00:00
|
|
|
struct in_addr;
|
2012-01-12 22:49:36 +00:00
|
|
|
struct pidfh;
|
2012-01-11 22:12:45 +00:00
|
|
|
struct sockaddr;
|
|
|
|
struct termios;
|
|
|
|
struct winsize;
|
1996-01-01 08:27:41 +00:00
|
|
|
|
|
|
|
__BEGIN_DECLS
|
2012-01-11 22:33:41 +00:00
|
|
|
char *auth_getval(const char *_name);
|
2004-02-26 22:44:11 +00:00
|
|
|
void clean_environment(const char * const *_white,
|
|
|
|
const char * const *_more_white);
|
2012-01-11 22:12:45 +00:00
|
|
|
int expand_number(const char *_buf, uint64_t *_num);
|
2002-03-21 23:54:04 +00:00
|
|
|
int extattr_namespace_to_string(int _attrnamespace, char **_string);
|
2002-03-22 09:22:15 +00:00
|
|
|
int extattr_string_to_namespace(const char *_string, int *_attrnamespace);
|
2007-05-10 15:01:42 +00:00
|
|
|
int flopen(const char *_path, int _flags, ...);
|
2017-08-04 14:24:24 +00:00
|
|
|
int flopenat(int _dirfd, const char *_path, int _flags, ...);
|
2002-03-22 09:22:15 +00:00
|
|
|
int forkpty(int *_amaster, char *_name,
|
2012-01-11 22:45:15 +00:00
|
|
|
struct termios *_termp, struct winsize *_winp);
|
2012-01-11 22:33:41 +00:00
|
|
|
void hexdump(const void *_ptr, int _length, const char *_hdr, int _flags);
|
2004-05-24 22:19:27 +00:00
|
|
|
int humanize_number(char *_buf, size_t _len, int64_t _number,
|
|
|
|
const char *_suffix, int _scale, int _flags);
|
2008-12-02 06:50:26 +00:00
|
|
|
struct kinfo_file *
|
|
|
|
kinfo_getfile(pid_t _pid, int *_cntp);
|
|
|
|
struct kinfo_vmentry *
|
|
|
|
kinfo_getvmmap(pid_t _pid, int *_cntp);
|
2015-05-27 18:11:05 +00:00
|
|
|
struct kinfo_vmobject *
|
|
|
|
kinfo_getvmobject(int *_cntp);
|
2011-05-12 10:11:39 +00:00
|
|
|
struct kinfo_proc *
|
|
|
|
kinfo_getallproc(int *_cntp);
|
|
|
|
struct kinfo_proc *
|
|
|
|
kinfo_getproc(pid_t _pid);
|
2012-01-11 22:33:41 +00:00
|
|
|
int kld_isloaded(const char *_name);
|
|
|
|
int kld_load(const char *_name);
|
2012-01-11 22:12:45 +00:00
|
|
|
int login_tty(int _fd);
|
|
|
|
int openpty(int *_amaster, int *_aslave, char *_name,
|
2012-01-11 22:45:15 +00:00
|
|
|
struct termios *_termp, struct winsize *_winp);
|
2012-01-16 21:19:23 +00:00
|
|
|
int pidfile_close(struct pidfh *_pfh);
|
|
|
|
int pidfile_fileno(const struct pidfh *_pfh);
|
|
|
|
struct pidfh *
|
|
|
|
pidfile_open(const char *_path, mode_t _mode, pid_t *_pidptr);
|
|
|
|
int pidfile_remove(struct pidfh *_pfh);
|
|
|
|
int pidfile_write(struct pidfh *_pfh);
|
2012-01-11 22:33:41 +00:00
|
|
|
void properties_free(properties _list);
|
|
|
|
char *property_find(properties _list, const char *_name);
|
2012-01-11 22:45:15 +00:00
|
|
|
properties
|
2012-01-12 14:40:25 +00:00
|
|
|
properties_read(int _fd);
|
2012-01-11 22:33:41 +00:00
|
|
|
int realhostname(char *_host, size_t _hsize, const struct in_addr *_ip);
|
|
|
|
int realhostname_sa(char *_host, size_t _hsize, struct sockaddr *_addr,
|
2012-01-11 22:45:15 +00:00
|
|
|
int _addrlen);
|
2012-01-11 22:12:45 +00:00
|
|
|
int _secure_path(const char *_path, uid_t _uid, gid_t _gid);
|
|
|
|
void trimdomain(char *_fullhost, int _hostsize);
|
2012-01-11 22:45:15 +00:00
|
|
|
const char *
|
|
|
|
uu_lockerr(int _uu_lockresult);
|
2012-01-11 22:12:45 +00:00
|
|
|
int uu_lock(const char *_ttyname);
|
|
|
|
int uu_unlock(const char *_ttyname);
|
|
|
|
int uu_lock_txfr(const char *_ttyname, pid_t _pid);
|
2006-02-18 11:25:28 +00:00
|
|
|
|
2012-01-26 20:35:01 +00:00
|
|
|
/*
|
|
|
|
* Conditionally prototype the following functions if the include
|
|
|
|
* files upon which they depend have been included.
|
|
|
|
*/
|
|
|
|
#ifdef _STDIO_H_
|
2012-01-11 22:45:15 +00:00
|
|
|
char *fparseln(FILE *_fp, size_t *_len, size_t *_lineno,
|
|
|
|
const char _delim[3], int _flags);
|
1999-12-29 17:50:34 +00:00
|
|
|
#endif
|
2002-05-08 00:50:07 +00:00
|
|
|
|
|
|
|
#ifdef _PWD_H_
|
2012-01-12 14:40:25 +00:00
|
|
|
int pw_copy(int _ffd, int _tfd, const struct passwd *_pw,
|
|
|
|
struct passwd *_old_pw);
|
|
|
|
struct passwd
|
|
|
|
*pw_dup(const struct passwd *_pw);
|
2002-05-08 00:50:07 +00:00
|
|
|
int pw_edit(int _notsetuid);
|
2003-10-18 10:04:16 +00:00
|
|
|
int pw_equal(const struct passwd *_pw1, const struct passwd *_pw2);
|
2002-05-08 00:50:07 +00:00
|
|
|
void pw_fini(void);
|
|
|
|
int pw_init(const char *_dir, const char *_master);
|
2003-10-18 10:04:16 +00:00
|
|
|
char *pw_make(const struct passwd *_pw);
|
2012-01-05 10:40:24 +00:00
|
|
|
char *pw_make_v7(const struct passwd *_pw);
|
2002-05-08 00:50:07 +00:00
|
|
|
int pw_mkdb(const char *_user);
|
|
|
|
int pw_lock(void);
|
2012-01-26 20:40:22 +00:00
|
|
|
struct passwd *
|
|
|
|
pw_scan(const char *_line, int _flags);
|
|
|
|
const char *
|
|
|
|
pw_tempname(void);
|
2002-05-08 00:50:07 +00:00
|
|
|
int pw_tmp(int _mfd);
|
|
|
|
#endif
|
2005-08-24 17:21:38 +00:00
|
|
|
|
2008-04-23 00:49:13 +00:00
|
|
|
#ifdef _GRP_H_
|
2012-01-12 14:40:25 +00:00
|
|
|
int gr_copy(int __ffd, int _tfd, const struct group *_gr,
|
|
|
|
struct group *_old_gr);
|
2012-01-26 20:40:22 +00:00
|
|
|
struct group *
|
|
|
|
gr_dup(const struct group *_gr);
|
2012-12-27 14:30:19 +00:00
|
|
|
struct group *
|
2013-03-07 19:00:00 +00:00
|
|
|
gr_add(const struct group *_gr, const char *_newmember);
|
2012-01-11 22:33:41 +00:00
|
|
|
int gr_equal(const struct group *_gr1, const struct group *_gr2);
|
2011-12-15 22:07:36 +00:00
|
|
|
void gr_fini(void);
|
|
|
|
int gr_init(const char *_dir, const char *_master);
|
|
|
|
int gr_lock(void);
|
2012-01-11 22:33:41 +00:00
|
|
|
char *gr_make(const struct group *_gr);
|
2011-12-15 22:07:36 +00:00
|
|
|
int gr_mkdb(void);
|
2012-01-26 20:40:22 +00:00
|
|
|
struct group *
|
|
|
|
gr_scan(const char *_line);
|
2011-12-15 22:07:36 +00:00
|
|
|
int gr_tmp(int _mdf);
|
2008-04-23 00:49:13 +00:00
|
|
|
#endif
|
|
|
|
|
2009-01-30 13:54:03 +00:00
|
|
|
#ifdef _UFS_UFS_QUOTA_H_
|
2009-02-13 06:12:15 +00:00
|
|
|
struct fstab;
|
2012-01-11 22:12:45 +00:00
|
|
|
struct quotafile;
|
2012-01-11 22:45:15 +00:00
|
|
|
int quota_check_path(const struct quotafile *_qf, const char *_path);
|
|
|
|
void quota_close(struct quotafile *_qf);
|
|
|
|
int quota_convert(struct quotafile *_qf, int _wordsize);
|
|
|
|
const char *
|
|
|
|
quota_fsname(const struct quotafile *_qf);
|
|
|
|
int quota_maxid(struct quotafile *_qf);
|
|
|
|
int quota_off(struct quotafile *_qf);
|
|
|
|
int quota_on(struct quotafile *_qf);
|
|
|
|
struct quotafile *
|
|
|
|
quota_open(struct fstab *_fs, int _quotatype, int _openflags);
|
|
|
|
const char *
|
|
|
|
quota_qfname(const struct quotafile *_qf);
|
|
|
|
int quota_read(struct quotafile *_qf, struct dqblk *_dqb, int _id);
|
|
|
|
int quota_write_limits(struct quotafile *_qf, struct dqblk *_dqb, int _id);
|
|
|
|
int quota_write_usage(struct quotafile *_qf, struct dqblk *_dqb, int _id);
|
2009-01-30 13:54:03 +00:00
|
|
|
#endif
|
|
|
|
|
1996-01-01 08:27:41 +00:00
|
|
|
__END_DECLS
|
|
|
|
|
1999-12-29 17:50:34 +00:00
|
|
|
/* fparseln(3) */
|
|
|
|
#define FPARSELN_UNESCESC 0x01
|
|
|
|
#define FPARSELN_UNESCCONT 0x02
|
|
|
|
#define FPARSELN_UNESCCOMM 0x04
|
|
|
|
#define FPARSELN_UNESCREST 0x08
|
|
|
|
#define FPARSELN_UNESCALL 0x0f
|
|
|
|
|
2012-01-16 21:19:23 +00:00
|
|
|
/* Flags for hexdump(3). */
|
2008-07-01 22:30:57 +00:00
|
|
|
#define HD_COLUMN_MASK 0xff
|
|
|
|
#define HD_DELIM_MASK 0xff00
|
|
|
|
#define HD_OMIT_COUNT (1 << 16)
|
|
|
|
#define HD_OMIT_HEX (1 << 17)
|
|
|
|
#define HD_OMIT_CHARS (1 << 18)
|
|
|
|
|
2012-01-26 20:35:01 +00:00
|
|
|
/* Values for humanize_number(3)'s flags parameter. */
|
2012-01-16 21:19:23 +00:00
|
|
|
#define HN_DECIMAL 0x01
|
|
|
|
#define HN_NOSPACE 0x02
|
|
|
|
#define HN_B 0x04
|
|
|
|
#define HN_DIVISOR_1000 0x08
|
|
|
|
#define HN_IEC_PREFIXES 0x10
|
|
|
|
|
2012-01-26 20:35:01 +00:00
|
|
|
/* Values for humanize_number(3)'s scale parameter. */
|
2012-01-16 21:19:23 +00:00
|
|
|
#define HN_GETSCALE 0x10
|
|
|
|
#define HN_AUTOSCALE 0x20
|
|
|
|
|
2012-01-26 20:35:01 +00:00
|
|
|
/* Return values from realhostname(). */
|
2012-01-16 21:19:23 +00:00
|
|
|
#define HOSTNAME_FOUND 0
|
|
|
|
#define HOSTNAME_INCORRECTNAME 1
|
|
|
|
#define HOSTNAME_INVALIDADDR 2
|
|
|
|
#define HOSTNAME_INVALIDNAME 3
|
|
|
|
|
|
|
|
/* Flags for pw_scan(). */
|
|
|
|
#define PWSCAN_MASTER 0x01
|
|
|
|
#define PWSCAN_WARN 0x02
|
|
|
|
|
|
|
|
/* Return values from uu_lock(). */
|
|
|
|
#define UU_LOCK_INUSE 1
|
|
|
|
#define UU_LOCK_OK 0
|
2012-01-26 20:33:08 +00:00
|
|
|
#define UU_LOCK_OPEN_ERR (-1)
|
|
|
|
#define UU_LOCK_READ_ERR (-2)
|
|
|
|
#define UU_LOCK_CREAT_ERR (-3)
|
|
|
|
#define UU_LOCK_WRITE_ERR (-4)
|
|
|
|
#define UU_LOCK_LINK_ERR (-5)
|
|
|
|
#define UU_LOCK_TRY_ERR (-6)
|
|
|
|
#define UU_LOCK_OWNER_ERR (-7)
|
2012-01-16 21:19:23 +00:00
|
|
|
|
1996-01-01 08:27:41 +00:00
|
|
|
#endif /* !_LIBUTIL_H_ */
|