X7ROOT File Manager
Current Path:
/usr/include
usr
/
include
/
📁
..
📄
FlexLexer.h
(6.07 KB)
📁
GL
📁
ImageMagick-6
📁
X11
📄
_G_config.h
(1.26 KB)
📄
a.out.h
(4.25 KB)
📄
aio.h
(7.27 KB)
📄
aliases.h
(2 KB)
📄
alloca.h
(1.19 KB)
📄
ar.h
(1.68 KB)
📄
argp.h
(24.75 KB)
📄
argz.h
(6.96 KB)
📁
arpa
📁
asm
📁
asm-generic
📄
assert.h
(3.52 KB)
📄
autosprintf.h
(2.33 KB)
📁
bind9
📁
bits
📄
byteswap.h
(1.41 KB)
📄
bzlib.h
(6.1 KB)
📁
c++
📄
com_err.h
(2.07 KB)
📄
complex.h
(3.62 KB)
📄
cpio.h
(2.21 KB)
📄
cpufreq.h
(5.8 KB)
📄
crypt.h
(2.22 KB)
📄
ctype.h
(11.52 KB)
📄
curses.h
(93.19 KB)
📄
cursesapp.h
(6.62 KB)
📄
cursesf.h
(27.05 KB)
📄
cursesm.h
(19.09 KB)
📄
cursesp.h
(8.3 KB)
📄
cursesw.h
(48.24 KB)
📄
cursslk.h
(7.13 KB)
📄
db.h
(120.21 KB)
📁
db4.7.25
📄
db_185.h
(5.84 KB)
📄
dbm.h
(1.37 KB)
📄
dirent.h
(12.34 KB)
📄
dlfcn.h
(6.88 KB)
📁
drm
📁
e2p
📄
elf.h
(141.01 KB)
📄
endian.h
(2.95 KB)
📄
entities.h
(4.56 KB)
📄
envz.h
(2.82 KB)
📄
err.h
(2.18 KB)
📄
errno.h
(2.33 KB)
📄
error.h
(2.01 KB)
📁
et
📄
eti.h
(2.82 KB)
📄
etip.h
(9.04 KB)
📄
execinfo.h
(1.5 KB)
📄
expat.h
(40.92 KB)
📄
expat_external.h
(3.29 KB)
📁
ext2fs
📄
fcntl.h
(9.89 KB)
📄
features.h
(12.87 KB)
📄
fenv.h
(4.5 KB)
📄
fmtmsg.h
(3.18 KB)
📄
fnmatch.h
(2.27 KB)
📁
fontconfig
📄
form.h
(17.56 KB)
📄
fpu_control.h
(3.5 KB)
📁
freetype2
📄
fstab.h
(3.04 KB)
📄
fts.h
(5.17 KB)
📄
ftw.h
(5.15 KB)
📄
gconv.h
(5.16 KB)
📄
gcrypt-module.h
(7.18 KB)
📄
gcrypt.h
(76.51 KB)
📄
gd.h
(32.02 KB)
📄
gd_io.h
(1.13 KB)
📁
gdbm
📄
gdbm.h
(5.75 KB)
📄
gdcache.h
(2.75 KB)
📄
gdfontg.h
(623 B)
📄
gdfontl.h
(621 B)
📄
gdfontmb.h
(590 B)
📄
gdfonts.h
(585 B)
📄
gdfontt.h
(617 B)
📄
gdfx.h
(2.34 KB)
📄
getopt.h
(6.53 KB)
📄
gettext-po.h
(15.17 KB)
📁
ghostscript
📄
glob.h
(6.51 KB)
📄
gmp-mparam-x86_64.h
(11.25 KB)
📄
gmp-mparam.h
(2.42 KB)
📄
gmp-x86_64.h
(81.3 KB)
📄
gmp.h
(2.24 KB)
📄
gmpxx.h
(110.49 KB)
📁
gnu
📄
gnu-versions.h
(2.29 KB)
📄
gpg-error.h
(23.66 KB)
📄
grp.h
(6.75 KB)
📄
gshadow.h
(4.43 KB)
📁
gssapi
📄
gssapi.h
(181 B)
📁
gssrpc
📄
iconv.h
(1.83 KB)
📄
idn-free.h
(2.41 KB)
📄
idn-int.h
(20 B)
📄
idna.h
(3.48 KB)
📄
ieee754.h
(4.81 KB)
📄
ifaddrs.h
(2.77 KB)
📁
ijs
📄
inttypes.h
(11.61 KB)
📁
jasper
📄
jconfig.h
(1.7 KB)
📄
jerror.h
(14.4 KB)
📄
jmorecfg.h
(13.5 KB)
📄
jpeglib.h
(49.12 KB)
📁
kadm5
📄
kdb.h
(60.12 KB)
📄
keyutils.h
(7.08 KB)
📄
krad.h
(8.72 KB)
📁
krb5
📄
krb5.h
(402 B)
📄
langinfo.h
(15.57 KB)
📄
lastlog.h
(126 B)
📄
libaio.h
(7.8 KB)
📁
libdb
📁
libexslt
📄
libgen.h
(1.37 KB)
📄
libintl.h
(4.49 KB)
📄
libio.h
(16.87 KB)
📁
libltdl
📁
libpng15
📁
libxml2
📁
libxslt
📄
limits.h
(4.42 KB)
📄
link.h
(6.99 KB)
📁
linux
📄
locale.h
(7.78 KB)
📄
ltdl.h
(5.58 KB)
📁
lzma
📄
lzma.h
(9.51 KB)
📄
malloc.h
(6.44 KB)
📄
math.h
(15.7 KB)
📄
mcheck.h
(2.4 KB)
📄
memory.h
(962 B)
📄
menu.h
(11.67 KB)
📁
misc
📄
mntent.h
(3.3 KB)
📄
monetary.h
(1.73 KB)
📄
mqueue.h
(3.7 KB)
📁
mtd
📁
mysql
📄
nc_tparm.h
(4.05 KB)
📁
ncurses
📄
ncurses.h
(93.19 KB)
📄
ncurses_dll.h
(3.83 KB)
📁
ncursesw
📄
ndbm.h
(2.39 KB)
📁
net
📁
netash
📁
netatalk
📁
netax25
📄
netdb.h
(27.46 KB)
📁
neteconet
📁
netinet
📁
netipx
📁
netiucv
📁
netpacket
📁
netrom
📁
netrose
📁
nfs
📄
nl_types.h
(1.73 KB)
📄
nss.h
(1.85 KB)
📄
obstack.h
(18.84 KB)
📁
openssl
📄
panel.h
(3.97 KB)
📄
paths.h
(2.91 KB)
📄
pcre.h
(29.73 KB)
📄
pcre_scanner.h
(6.45 KB)
📄
pcre_stringpiece.h
(6.11 KB)
📄
pcrecpp.h
(25.91 KB)
📄
pcrecpparg.h
(6.62 KB)
📄
pcreposix.h
(5.32 KB)
📄
png.h
(113.36 KB)
📄
pngconf.h
(20.94 KB)
📄
pnglibconf.h
(6.3 KB)
📄
poll.h
(22 B)
📄
pr29.h
(2.07 KB)
📄
printf.h
(6.56 KB)
📄
profile.h
(11.87 KB)
📁
protocols
📄
pthread.h
(39.95 KB)
📄
pty.h
(1.51 KB)
📄
punycode.h
(9.36 KB)
📄
pwd.h
(5.87 KB)
📁
python2.7
📁
quota
📁
rdma
📄
re_comp.h
(957 B)
📄
regex.h
(21.58 KB)
📄
regexp.h
(6.89 KB)
📄
resolv.h
(14.67 KB)
📁
rpc
📁
rpcsvc
📄
sched.h
(4.55 KB)
📁
scsi
📄
search.h
(5.11 KB)
📁
security
📁
selinux
📄
semaphore.h
(2.36 KB)
📁
sepol
📄
setjmp.h
(3.97 KB)
📄
sgtty.h
(1.33 KB)
📄
shadow.h
(5.1 KB)
📄
signal.h
(13.3 KB)
📁
sound
📄
spawn.h
(6.53 KB)
📄
stab.h
(264 B)
📄
stdc-predef.h
(1.59 KB)
📄
stdint.h
(7.94 KB)
📄
stdio.h
(30.9 KB)
📄
stdio_ext.h
(2.74 KB)
📄
stdlib.h
(33.23 KB)
📄
string.h
(21.75 KB)
📄
stringprep.h
(8 KB)
📄
strings.h
(4.55 KB)
📁
sys
📄
syscall.h
(25 B)
📄
sysexits.h
(5.11 KB)
📄
syslog.h
(24 B)
📄
tar.h
(3.67 KB)
📄
tcpd.h
(11.48 KB)
📄
term.h
(38.63 KB)
📄
term_entry.h
(7.91 KB)
📄
termcap.h
(3.4 KB)
📄
termio.h
(214 B)
📄
termios.h
(3.52 KB)
📄
tgmath.h
(18.11 KB)
📄
thread_db.h
(15.65 KB)
📄
tic.h
(12.35 KB)
📄
tiff.h
(34.95 KB)
📄
tiffconf-64.h
(3.35 KB)
📄
tiffconf.h
(250 B)
📄
tiffio.h
(23.14 KB)
📄
tiffio.hxx
(1.66 KB)
📄
tiffvers.h
(410 B)
📄
time.h
(13.4 KB)
📄
tld.h
(4.54 KB)
📄
ttyent.h
(2.44 KB)
📁
uapi
📄
uchar.h
(2.42 KB)
📄
ucontext.h
(1.92 KB)
📄
ulimit.h
(1.55 KB)
📄
unctrl.h
(3.03 KB)
📄
unistd.h
(41.78 KB)
📄
ustat.h
(23 B)
📄
utime.h
(1.5 KB)
📄
utmp.h
(3.16 KB)
📄
utmpx.h
(4.02 KB)
📁
uuid
📄
values.h
(1.92 KB)
📄
verto-module.h
(6.48 KB)
📄
verto.h
(18.57 KB)
📁
video
📄
wait.h
(22 B)
📄
wchar.h
(31.37 KB)
📄
wctype.h
(10.89 KB)
📄
wordexp.h
(2.47 KB)
📁
xcb
📁
xen
📄
xlocale.h
(1.66 KB)
📄
zconf.h
(14.92 KB)
📄
zlib.h
(84.68 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