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