X7ROOT File Manager
Current Path:
/usr/include
usr
/
include
/
ðŸ“
..
📄
FlexLexer.h
(6.73 KB)
ðŸ“
GL
ðŸ“
X11
📄
a.out.h
(4.25 KB)
📄
aio.h
(7.28 KB)
📄
aliases.h
(1.98 KB)
📄
alloca.h
(1.17 KB)
ðŸ“
apache2
📄
ar.h
(1.69 KB)
📄
argp.h
(24.82 KB)
📄
argz.h
(5.91 KB)
ðŸ“
arpa
ðŸ“
asm
ðŸ“
asm-generic
📄
assert.h
(4.45 KB)
📄
autosprintf.h
(2.33 KB)
ðŸ“
bind9
ðŸ“
bits
ðŸ“
bsock
📄
byteswap.h
(1.37 KB)
📄
bzlib.h
(6.1 KB)
ðŸ“
c++
📄
com_err.h
(2.07 KB)
📄
complex.h
(7 KB)
📄
cpio.h
(2.21 KB)
📄
cpuidle.h
(844 B)
ðŸ“
criu
📄
crypt.h
(8.9 KB)
📄
ctype.h
(10.71 KB)
ðŸ“
curl
📄
curses.h
(97.29 KB)
📄
cursesapp.h
(6.62 KB)
📄
cursesf.h
(27.2 KB)
📄
cursesm.h
(19.22 KB)
📄
cursesp.h
(8.4 KB)
📄
cursesw.h
(48.55 KB)
📄
cursslk.h
(7.13 KB)
📄
db.h
(120.22 KB)
📄
db_185.h
(5.84 KB)
📄
dbm.h
(1.38 KB)
📄
dirent.h
(12.19 KB)
📄
dlfcn.h
(7.07 KB)
ðŸ“
drm
ðŸ“
e2p
📄
elf.h
(170.73 KB)
📄
endian.h
(3.11 KB)
📄
entities.h
(4.81 KB)
📄
envz.h
(2.8 KB)
📄
err.h
(2.16 KB)
📄
errno.h
(1.64 KB)
📄
error.h
(1.99 KB)
ðŸ“
et
📄
eti.h
(2.82 KB)
📄
etip.h
(9.47 KB)
📄
evdns.h
(1.97 KB)
📄
event.h
(2.68 KB)
ðŸ“
event2
📄
evhttp.h
(1.99 KB)
📄
evrpc.h
(1.97 KB)
📄
evutil.h
(1.74 KB)
📄
execinfo.h
(1.49 KB)
📄
expat.h
(42.66 KB)
📄
expat_config.h
(3.43 KB)
📄
expat_external.h
(5.4 KB)
ðŸ“
ext2fs
📄
fcntl.h
(10.7 KB)
📄
features.h
(15.69 KB)
📄
fenv.h
(5.72 KB)
ðŸ“
finclude
📄
fmtmsg.h
(3.16 KB)
📄
fnmatch.h
(2.24 KB)
ðŸ“
fontconfig
📄
form.h
(18.17 KB)
📄
fpu_control.h
(3.5 KB)
ðŸ“
freetype2
📄
fstab.h
(3.04 KB)
ðŸ“
fstrm
📄
fstrm.h
(12.71 KB)
📄
fts.h
(8.18 KB)
📄
ftw.h
(5.13 KB)
📄
gconv.h
(4.31 KB)
📄
gcrypt.h
(68.71 KB)
📄
gd.h
(56.42 KB)
📄
gd_color_map.h
(478 B)
📄
gd_errors.h
(1.47 KB)
📄
gd_io.h
(3.05 KB)
ðŸ“
gdb
ðŸ“
gdbm
📄
gdbm.h
(10.1 KB)
📄
gdcache.h
(2.83 KB)
📄
gdfontg.h
(553 B)
📄
gdfontl.h
(551 B)
📄
gdfontmb.h
(519 B)
📄
gdfonts.h
(515 B)
📄
gdfontt.h
(546 B)
📄
gdfx.h
(497 B)
📄
gdpp.h
(50.94 KB)
📄
gelf.h
(11.14 KB)
📄
getopt.h
(1.43 KB)
📄
gettext-po.h
(15.17 KB)
📄
glob.h
(6.46 KB)
ðŸ“
gnu
📄
gnu-versions.h
(2.29 KB)
📄
gnumake.h
(2.84 KB)
ðŸ“
google
📄
gpg-error.h
(66.29 KB)
📄
gpgrt.h
(66.29 KB)
📄
grp.h
(6.53 KB)
📄
gshadow.h
(4.42 KB)
ðŸ“
gssapi
📄
gssapi.h
(181 B)
ðŸ“
gssrpc
📄
iconv.h
(1.81 KB)
📄
idn-free.h
(2.41 KB)
📄
idn-int.h
(20 B)
📄
idna.h
(3.48 KB)
📄
ieee754.h
(4.79 KB)
📄
ifaddrs.h
(2.77 KB)
📄
inttypes.h
(11.61 KB)
📄
jconfig-64.h
(2.17 KB)
📄
jconfig.h
(246 B)
📄
jerror.h
(14.73 KB)
📄
jmorecfg.h
(14.7 KB)
📄
jpegint.h
(15.22 KB)
📄
jpeglib.h
(48.71 KB)
ðŸ“
json-c
ðŸ“
kadm5
📄
kdb.h
(67.66 KB)
📄
keyutils.h
(7.52 KB)
📄
krad.h
(8.72 KB)
ðŸ“
krb5
📄
krb5.h
(402 B)
📄
langinfo.h
(17.43 KB)
📄
lastlog.h
(126 B)
📄
lber.h
(14.95 KB)
📄
lber_types.h
(1.43 KB)
📄
ldap.h
(63.57 KB)
📄
ldap_cdefs.h
(9.24 KB)
📄
ldap_features.h
(1.77 KB)
📄
ldap_schema.h
(9.23 KB)
📄
ldap_utf8.h
(3.39 KB)
📄
ldif.h
(4.58 KB)
📄
libaio.h
(8.73 KB)
ðŸ“
libdb
📄
libelf.h
(19.84 KB)
ðŸ“
libexslt
📄
libgen.h
(1.35 KB)
📄
libintl.h
(4.47 KB)
ðŸ“
libltdl
ðŸ“
libpng16
ðŸ“
libxml2
ðŸ“
libxslt
📄
limits.h
(5.29 KB)
📄
link.h
(7.05 KB)
ðŸ“
linux
📄
locale.h
(7.49 KB)
📄
ltdl.h
(5.58 KB)
ðŸ“
lua-5.1
ðŸ“
lzma
📄
lzma.h
(9.59 KB)
📄
magic.h
(5.46 KB)
📄
malloc.h
(5.96 KB)
📄
math.h
(52.07 KB)
📄
mcheck.h
(2.38 KB)
📄
memory.h
(955 B)
📄
menu.h
(11.91 KB)
ðŸ“
misc
📄
mntent.h
(3.28 KB)
📄
monetary.h
(1.76 KB)
📄
mqueue.h
(3.67 KB)
ðŸ“
mtd
ðŸ“
mysql
📄
nc_tparm.h
(4.1 KB)
ðŸ“
ncurses
📄
ncurses.h
(97.29 KB)
📄
ncurses_dll.h
(4.18 KB)
ðŸ“
ncursesw
📄
ndbm.h
(2.4 KB)
ðŸ“
net
ðŸ“
netash
ðŸ“
netatalk
ðŸ“
netax25
📄
netdb.h
(27.44 KB)
ðŸ“
neteconet
ðŸ“
netinet
ðŸ“
netipx
ðŸ“
netiucv
ðŸ“
netpacket
ðŸ“
netrom
ðŸ“
netrose
ðŸ“
nfs
📄
nl_types.h
(1.71 KB)
📄
nlist.h
(1.56 KB)
📄
nss.h
(1.83 KB)
📄
obstack.h
(20.81 KB)
ðŸ“
openssl
📄
panel.h
(4.03 KB)
📄
paths.h
(2.91 KB)
📄
pcre.h
(30.97 KB)
📄
pcre2.h
(43.75 KB)
📄
pcre2posix.h
(5.67 KB)
📄
pcre_scanner.h
(6.45 KB)
📄
pcre_stringpiece.h
(6.16 KB)
📄
pcrecpp.h
(25.91 KB)
📄
pcrecpparg.h
(6.62 KB)
📄
pcreposix.h
(5.32 KB)
ðŸ“
perf
📄
png.h
(140.77 KB)
📄
pngconf.h
(22.31 KB)
📄
pnglibconf.h
(7.39 KB)
📄
poll.h
(22 B)
📄
pr29.h
(2.07 KB)
📄
printf.h
(6.64 KB)
📄
proc_service.h
(3.39 KB)
📄
profile.h
(11.87 KB)
ðŸ“
protobuf-c
ðŸ“
protocols
📄
pthread.h
(40.3 KB)
📄
pty.h
(1.53 KB)
📄
punycode.h
(9.16 KB)
📄
pwd.h
(6.01 KB)
ðŸ“
python2.7
ðŸ“
python3.6m
ðŸ“
python3.8
ðŸ“
rdma
📄
re_comp.h
(962 B)
📄
regex.h
(24.14 KB)
📄
regexp.h
(1.41 KB)
📄
resolv.h
(11.79 KB)
ðŸ“
rpc
ðŸ“
sasl
📄
sched.h
(4.62 KB)
ðŸ“
scsi
📄
search.h
(5.1 KB)
ðŸ“
security
ðŸ“
selinux
📄
semaphore.h
(2.34 KB)
ðŸ“
sepol
📄
setjmp.h
(3.58 KB)
📄
sgtty.h
(1.31 KB)
📄
shadow.h
(5.34 KB)
📄
signal.h
(11.96 KB)
📄
slapi-plugin.h
(37.45 KB)
ðŸ“
sound
📄
spawn.h
(6.53 KB)
📄
stab.h
(264 B)
📄
stdc-predef.h
(2.24 KB)
📄
stdint.h
(8.27 KB)
📄
stdio.h
(29.46 KB)
📄
stdio_ext.h
(2.73 KB)
📄
stdlib.h
(34.82 KB)
📄
string.h
(17.17 KB)
📄
stringprep.h
(8.03 KB)
📄
strings.h
(4.64 KB)
ðŸ“
sys
📄
syscall.h
(25 B)
📄
sysexits.h
(5.11 KB)
📄
syslog.h
(24 B)
📄
tar.h
(3.7 KB)
📄
term.h
(40.22 KB)
📄
term_entry.h
(8.55 KB)
📄
termcap.h
(3.39 KB)
📄
termio.h
(214 B)
📄
termios.h
(3.51 KB)
📄
tgmath.h
(30.75 KB)
📄
thread_db.h
(15.65 KB)
📄
threads.h
(6.5 KB)
📄
tic.h
(13.32 KB)
📄
tiff.h
(35.14 KB)
📄
tiffconf-64.h
(3.35 KB)
📄
tiffconf.h
(250 B)
📄
tiffio.h
(22.68 KB)
📄
tiffio.hxx
(1.66 KB)
📄
tiffvers.h
(410 B)
📄
time.h
(10.12 KB)
📄
tld.h
(4.54 KB)
📄
ttyent.h
(2.44 KB)
📄
uchar.h
(1.95 KB)
📄
ucontext.h
(1.99 KB)
📄
ulimit.h
(1.55 KB)
📄
unctrl.h
(3.03 KB)
📄
unistd.h
(41.74 KB)
📄
utime.h
(1.47 KB)
📄
utmp.h
(3.15 KB)
📄
utmpx.h
(4 KB)
ðŸ“
uuid
📄
values.h
(1.91 KB)
📄
verto-module.h
(6.48 KB)
📄
verto.h
(18.98 KB)
ðŸ“
video
📄
wait.h
(22 B)
📄
wchar.h
(30.38 KB)
📄
wctype.h
(5.42 KB)
ðŸ“
webp
📄
wordexp.h
(2.44 KB)
ðŸ“
xcb
ðŸ“
xen
📄
zbuff.h
(11.23 KB)
📄
zconf.h
(15.88 KB)
📄
zdict.h
(16.8 KB)
📄
zlib.h
(94 KB)
📄
zstd.h
(117.16 KB)
📄
zstd_errors.h
(3.66 KB)
Editing: krad.h
/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */ /* * Copyright 2013 Red Hat, Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 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. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS 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 COPYRIGHT OWNER * 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. */ /* * This API is not considered as stable as the main krb5 API. * * - We may make arbitrary incompatible changes between feature releases * (e.g. from 1.12 to 1.13). * - We will make some effort to avoid making incompatible changes for * bugfix releases, but will make them if necessary. */ #ifndef KRAD_H_ #define KRAD_H_ #include <krb5.h> #include <verto.h> #include <stddef.h> #include <stdio.h> #define KRAD_PACKET_SIZE_MAX 4096 #define KRAD_SERVICE_TYPE_LOGIN 1 #define KRAD_SERVICE_TYPE_FRAMED 2 #define KRAD_SERVICE_TYPE_CALLBACK_LOGIN 3 #define KRAD_SERVICE_TYPE_CALLBACK_FRAMED 4 #define KRAD_SERVICE_TYPE_OUTBOUND 5 #define KRAD_SERVICE_TYPE_ADMINISTRATIVE 6 #define KRAD_SERVICE_TYPE_NAS_PROMPT 7 #define KRAD_SERVICE_TYPE_AUTHENTICATE_ONLY 8 #define KRAD_SERVICE_TYPE_CALLBACK_NAS_PROMPT 9 #define KRAD_SERVICE_TYPE_CALL_CHECK 10 #define KRAD_SERVICE_TYPE_CALLBACK_ADMINISTRATIVE 11 typedef struct krad_attrset_st krad_attrset; typedef struct krad_packet_st krad_packet; typedef struct krad_client_st krad_client; typedef unsigned char krad_code; typedef unsigned char krad_attr; /* Called when a response is received or the request times out. */ typedef void (*krad_cb)(krb5_error_code retval, const krad_packet *request, const krad_packet *response, void *data); /* * Called to iterate over a set of requests. Either the callback will be * called until it returns NULL, or it will be called with cancel = TRUE to * terminate in the middle of an iteration. */ typedef const krad_packet * (*krad_packet_iter_cb)(void *data, krb5_boolean cancel); /* * Code */ /* Convert a code name to its number. Only works for codes defined * by RFC 2875 or 2882. Returns 0 if the name was not found. */ krad_code krad_code_name2num(const char *name); /* Convert a code number to its name. Only works for attributes defined * by RFC 2865 or 2882. Returns NULL if the name was not found. */ const char * krad_code_num2name(krad_code code); /* * Attribute */ /* Convert an attribute name to its number. Only works for attributes defined * by RFC 2865. Returns 0 if the name was not found. */ krad_attr krad_attr_name2num(const char *name); /* Convert an attribute number to its name. Only works for attributes defined * by RFC 2865. Returns NULL if the name was not found. */ const char * krad_attr_num2name(krad_attr type); /* * Attribute set */ /* Create a new attribute set. */ krb5_error_code krad_attrset_new(krb5_context ctx, krad_attrset **set); /* Create a deep copy of an attribute set. */ krb5_error_code krad_attrset_copy(const krad_attrset *set, krad_attrset **copy); /* Free an attribute set. */ void krad_attrset_free(krad_attrset *set); /* Add an attribute to a set. */ krb5_error_code krad_attrset_add(krad_attrset *set, krad_attr type, const krb5_data *data); /* Add a four-octet unsigned number attribute to the given set. */ krb5_error_code krad_attrset_add_number(krad_attrset *set, krad_attr type, krb5_ui_4 num); /* Delete the specified attribute. */ void krad_attrset_del(krad_attrset *set, krad_attr type, size_t indx); /* Get the specified attribute. */ const krb5_data * krad_attrset_get(const krad_attrset *set, krad_attr type, size_t indx); /* * Packet */ /* Determine the bytes needed from the socket to get the whole packet. Don't * cache the return value as it can change! Returns -1 on EBADMSG. */ ssize_t krad_packet_bytes_needed(const krb5_data *buffer); /* Free a packet. */ void krad_packet_free(krad_packet *pkt); /* * Create a new request packet. * * This function takes the attributes specified in set and converts them into a * radius packet. The packet will have a randomized id. If cb is not NULL, it * will be called passing data as the argument to iterate over a set of * outstanding requests. In this case, the id will be both random and unique * across the set of requests. */ krb5_error_code krad_packet_new_request(krb5_context ctx, const char *secret, krad_code code, const krad_attrset *set, krad_packet_iter_cb cb, void *data, krad_packet **request); /* * Create a new response packet. * * This function is similar to krad_packet_new_requst() except that it crafts a * packet in response to a request packet. This new packet will borrow values * from the request such as the id and the authenticator. */ krb5_error_code krad_packet_new_response(krb5_context ctx, const char *secret, krad_code code, const krad_attrset *set, const krad_packet *request, krad_packet **response); /* * Decode a request radius packet from krb5_data. * * The resulting decoded packet will be a request packet stored in *reqpkt. * * If cb is NULL, *duppkt will always be NULL. * * If cb is not NULL, it will be called (with the data argument) to iterate * over a set of requests currently being processed. In this case, if the * packet is a duplicate of an already received request, the original request * will be set in *duppkt. */ krb5_error_code krad_packet_decode_request(krb5_context ctx, const char *secret, const krb5_data *buffer, krad_packet_iter_cb cb, void *data, const krad_packet **duppkt, krad_packet **reqpkt); /* * Decode a response radius packet from krb5_data. * * The resulting decoded packet will be a response packet stored in *rsppkt. * * If cb is NULL, *reqpkt will always be NULL. * * If cb is not NULL, it will be called (with the data argument) to iterate * over a set of requests awaiting responses. In this case, if the response * packet matches one of these requests, the original request will be set in * *reqpkt. */ krb5_error_code krad_packet_decode_response(krb5_context ctx, const char *secret, const krb5_data *buffer, krad_packet_iter_cb cb, void *data, const krad_packet **reqpkt, krad_packet **rsppkt); /* Encode packet. */ const krb5_data * krad_packet_encode(const krad_packet *pkt); /* Get the code for the given packet. */ krad_code krad_packet_get_code(const krad_packet *pkt); /* Get the specified attribute. */ const krb5_data * krad_packet_get_attr(const krad_packet *pkt, krad_attr type, size_t indx); /* * Client */ /* Create a new client. */ krb5_error_code krad_client_new(krb5_context kctx, verto_ctx *vctx, krad_client **client); /* Free the client. */ void krad_client_free(krad_client *client); /* * Send a request to a radius server. * * The remote host may be specified by one of the following formats: * - /path/to/unix.socket * - IPv4 * - IPv4:port * - IPv4:service * - [IPv6] * - [IPv6]:port * - [IPv6]:service * - hostname * - hostname:port * - hostname:service * * The timeout parameter (milliseconds) is the total timeout across all remote * hosts (when DNS returns multiple entries) and all retries. For stream * sockets, the retries parameter is ignored and no retries are performed. * * The cb function will be called with the data argument when either a response * is received or the request times out on all possible remote hosts. */ krb5_error_code krad_client_send(krad_client *rc, krad_code code, const krad_attrset *attrs, const char *remote, const char *secret, int timeout, size_t retries, krad_cb cb, void *data); #endif /* KRAD_H_ */
Upload File
Create Folder