Linux business57.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64
LiteSpeed
Server IP : 199.188.201.191 & Your IP : 18.217.0.242
Domains :
Cant Read [ /etc/named.conf ]
User : derozboy
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
include /
Delete
Unzip
Name
Size
Permission
Date
Action
GL
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
X11
[ DIR ]
drwxr-xr-x
2024-09-27 08:36
apache2
[ DIR ]
drwxr-xr-x
2025-03-20 08:33
arpa
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
asm
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
asm-generic
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
bind9
[ DIR ]
drwxr-xr-x
2025-02-21 08:43
bits
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
bsock
[ DIR ]
drwxr-xr-x
2024-03-03 22:15
c++
[ DIR ]
drwxr-xr-x
2025-03-31 10:36
criu
[ DIR ]
drwxr-xr-x
2024-03-21 16:25
curl
[ DIR ]
drwxr-xr-x
2025-01-30 09:32
drm
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
e2p
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
et
[ DIR ]
drwxr-xr-x
2024-03-03 20:40
event2
[ DIR ]
drwxr-xr-x
2024-11-08 05:34
ext2fs
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
finclude
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
fontconfig
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
freetype2
[ DIR ]
drwxr-xr-x
2025-04-01 16:43
fstrm
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
gdb
[ DIR ]
drwxr-xr-x
2025-02-11 09:59
gdbm
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
gnu
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
google
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
gssapi
[ DIR ]
drwxr-xr-x
2025-03-18 04:43
gssrpc
[ DIR ]
drwxr-xr-x
2025-03-18 04:43
json-c
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
kadm5
[ DIR ]
drwxr-xr-x
2025-03-18 04:43
krb5
[ DIR ]
drwxr-xr-x
2025-03-18 04:43
libdb
[ DIR ]
drwxr-xr-x
2024-03-03 20:40
libexslt
[ DIR ]
drwxr-xr-x
2025-04-07 22:43
libltdl
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
libpng16
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
libxml2
[ DIR ]
drwxr-xr-x
2025-03-12 19:57
libxslt
[ DIR ]
drwxr-xr-x
2025-04-07 22:43
linux
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
lua-5.1
[ DIR ]
drwxr-xr-x
2024-07-23 08:42
lzma
[ DIR ]
drwxr-xr-x
2024-03-03 22:40
misc
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
mtd
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
mysql
[ DIR ]
drwxr-xr-x
2025-02-20 09:45
ncurses
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
ncursesw
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
net
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netash
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netatalk
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netax25
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
neteconet
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netinet
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netipx
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netiucv
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netpacket
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netrom
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
netrose
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
nfs
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
openssl
[ DIR ]
drwxr-xr-x
2024-10-12 08:31
perf
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
protobuf-c
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
protocols
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
python2.7
[ DIR ]
drwxr-xr-x
2024-06-14 07:36
python3.6m
[ DIR ]
drwxr-xr-x
2024-12-05 20:43
python3.8
[ DIR ]
drwxr-xr-x
2024-03-21 16:05
rdma
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
rpc
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
sasl
[ DIR ]
drwxr-xr-x
2024-03-03 20:40
scsi
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
security
[ DIR ]
drwxr-xr-x
2024-12-02 09:31
selinux
[ DIR ]
drwxr-xr-x
2025-03-13 08:41
sepol
[ DIR ]
drwxr-xr-x
2024-03-03 20:40
sound
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
sys
[ DIR ]
drwxr-xr-x
2025-04-14 19:44
uuid
[ DIR ]
drwxr-xr-x
2024-06-14 07:36
video
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
webp
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
xcb
[ DIR ]
drwxr-xr-x
2024-03-03 23:04
xen
[ DIR ]
drwxr-xr-x
2025-04-29 08:31
FlexLexer.h
6.73
KB
-rw-r--r--
2019-10-12 12:33
a.out.h
4.25
KB
-rw-r--r--
2025-04-14 07:23
aio.h
7.28
KB
-rw-r--r--
2025-04-14 07:24
aliases.h
1.98
KB
-rw-r--r--
2025-04-14 07:24
alloca.h
1.17
KB
-rw-r--r--
2025-04-14 07:23
ar.h
1.69
KB
-rw-r--r--
2025-04-14 07:23
argp.h
24.82
KB
-rw-r--r--
2025-04-14 07:24
argz.h
5.91
KB
-rw-r--r--
2025-04-14 07:23
assert.h
4.45
KB
-rw-r--r--
2025-04-14 07:23
autosprintf.h
2.33
KB
-rw-r--r--
2019-11-18 17:16
byteswap.h
1.37
KB
-rw-r--r--
2025-04-14 07:23
bzlib.h
6.1
KB
-rw-r--r--
2010-09-10 23:08
com_err.h
2.07
KB
-rw-r--r--
2020-03-21 04:24
complex.h
7
KB
-rw-r--r--
2025-04-14 07:23
cpio.h
2.21
KB
-rw-r--r--
2025-04-14 07:23
cpuidle.h
844
B
-rw-r--r--
2025-04-08 14:14
crypt.h
8.9
KB
-rw-r--r--
2021-10-09 04:04
ctype.h
10.71
KB
-rw-r--r--
2025-04-14 07:23
curses.h
97.29
KB
-rw-r--r--
2023-10-14 18:54
cursesapp.h
6.62
KB
-rw-r--r--
2023-10-14 18:54
cursesf.h
27.2
KB
-rw-r--r--
2023-10-14 18:54
cursesm.h
19.22
KB
-rw-r--r--
2023-10-14 18:54
cursesp.h
8.4
KB
-rw-r--r--
2023-10-14 18:54
cursesw.h
48.55
KB
-rw-r--r--
2023-10-14 18:54
cursslk.h
7.13
KB
-rw-r--r--
2023-10-14 18:54
db.h
120.22
KB
-r--r--r--
2021-09-21 16:29
db_185.h
5.84
KB
-r--r--r--
2021-09-21 16:29
dbm.h
1.38
KB
-rw-r--r--
2022-10-08 13:22
dirent.h
12.19
KB
-rw-r--r--
2025-04-14 07:23
dlfcn.h
7.07
KB
-rw-r--r--
2025-04-14 07:23
elf.h
170.73
KB
-rw-r--r--
2025-04-14 07:24
endian.h
3.11
KB
-rw-r--r--
2025-04-14 07:23
entities.h
4.81
KB
-rw-r--r--
2017-08-30 11:05
envz.h
2.8
KB
-rw-r--r--
2025-04-14 07:23
err.h
2.16
KB
-rw-r--r--
2025-04-14 07:23
errno.h
1.64
KB
-rw-r--r--
2025-04-14 07:23
error.h
1.99
KB
-rw-r--r--
2025-04-14 07:23
eti.h
2.82
KB
-rw-r--r--
2023-10-14 18:54
etip.h
9.47
KB
-rw-r--r--
2023-10-14 18:54
evdns.h
1.97
KB
-rw-r--r--
2019-10-12 00:29
event.h
2.68
KB
-rw-r--r--
2019-10-12 00:29
evhttp.h
1.99
KB
-rw-r--r--
2019-10-12 00:29
evrpc.h
1.97
KB
-rw-r--r--
2019-10-12 00:29
evutil.h
1.74
KB
-rw-r--r--
2019-10-12 00:29
execinfo.h
1.49
KB
-rw-r--r--
2025-04-14 07:24
expat.h
42.66
KB
-rw-r--r--
2025-04-15 19:58
expat_config.h
3.43
KB
-rw-r--r--
2025-04-15 19:58
expat_external.h
5.4
KB
-rw-r--r--
2025-04-15 19:58
fcntl.h
10.7
KB
-rw-r--r--
2025-04-14 07:23
features.h
15.69
KB
-rw-r--r--
2025-04-14 07:23
fenv.h
5.72
KB
-rw-r--r--
2025-04-14 07:23
fmtmsg.h
3.16
KB
-rw-r--r--
2025-04-14 07:23
fnmatch.h
2.24
KB
-rw-r--r--
2025-04-14 07:23
form.h
18.17
KB
-rw-r--r--
2023-10-14 18:54
fpu_control.h
3.5
KB
-rw-r--r--
2025-04-14 07:23
fstab.h
3.04
KB
-rw-r--r--
2025-04-14 07:23
fstrm.h
12.71
KB
-rw-r--r--
2019-03-11 20:58
fts.h
8.18
KB
-rw-r--r--
2025-04-14 07:23
ftw.h
5.13
KB
-rw-r--r--
2025-04-14 07:23
gconv.h
4.31
KB
-rw-r--r--
2025-04-14 07:23
gcrypt.h
68.71
KB
-rw-r--r--
2022-06-28 11:54
gd.h
56.42
KB
-rw-r--r--
2017-08-30 11:05
gd_color_map.h
478
B
-rw-r--r--
2017-08-30 11:05
gd_errors.h
1.47
KB
-rw-r--r--
2017-08-30 11:05
gd_io.h
3.05
KB
-rw-r--r--
2017-08-30 11:05
gdbm.h
10.1
KB
-rw-r--r--
2022-10-08 13:22
gdcache.h
2.83
KB
-rw-r--r--
2017-08-30 11:05
gdfontg.h
553
B
-rw-r--r--
2017-08-30 11:05
gdfontl.h
551
B
-rw-r--r--
2017-08-30 11:05
gdfontmb.h
519
B
-rw-r--r--
2017-08-30 11:05
gdfonts.h
515
B
-rw-r--r--
2017-08-30 11:05
gdfontt.h
546
B
-rw-r--r--
2017-08-30 11:05
gdfx.h
497
B
-rw-r--r--
2017-08-30 11:05
gdpp.h
50.94
KB
-rw-r--r--
2017-08-30 11:05
getopt.h
1.43
KB
-rw-r--r--
2025-04-14 07:23
gettext-po.h
15.17
KB
-rw-r--r--
2019-11-18 17:17
glob.h
6.46
KB
-rw-r--r--
2025-04-14 07:23
gnu-versions.h
2.29
KB
-rw-r--r--
2025-04-14 07:23
gnumake.h
2.84
KB
-rw-r--r--
2022-04-18 16:38
gpg-error.h
66.29
KB
-rw-r--r--
2019-10-12 12:20
gpgrt.h
66.29
KB
-rw-r--r--
2019-10-12 12:20
grp.h
6.53
KB
-rw-r--r--
2025-04-14 07:23
gshadow.h
4.42
KB
-rw-r--r--
2025-04-14 07:23
gssapi.h
181
B
-rw-r--r--
2025-03-13 12:14
iconv.h
1.81
KB
-rw-r--r--
2025-04-14 07:23
idn-free.h
2.41
KB
-rw-r--r--
2019-10-13 16:55
idn-int.h
20
B
-rw-r--r--
2019-10-13 16:55
idna.h
3.48
KB
-rw-r--r--
2019-10-13 16:55
ieee754.h
4.79
KB
-rw-r--r--
2025-04-14 07:23
ifaddrs.h
2.77
KB
-rw-r--r--
2025-04-14 07:24
inttypes.h
11.61
KB
-rw-r--r--
2025-04-14 07:23
jconfig-64.h
2.17
KB
-rw-r--r--
2021-10-09 01:29
jconfig.h
246
B
-rw-r--r--
2021-10-09 01:29
jerror.h
14.73
KB
-rw-r--r--
2021-10-09 01:29
jmorecfg.h
14.7
KB
-rw-r--r--
2021-10-09 01:29
jpegint.h
15.22
KB
-rw-r--r--
2021-10-09 01:29
jpeglib.h
48.71
KB
-rw-r--r--
2021-10-09 01:29
kdb.h
67.66
KB
-rw-r--r--
2025-03-13 12:14
keyutils.h
7.52
KB
-rw-r--r--
2021-10-08 13:50
krad.h
8.72
KB
-rw-r--r--
2025-03-13 12:14
krb5.h
402
B
-rw-r--r--
2025-03-13 12:14
langinfo.h
17.43
KB
-rw-r--r--
2025-04-14 07:23
lastlog.h
126
B
-rw-r--r--
2025-04-14 07:24
lber.h
14.95
KB
-rw-r--r--
2025-03-11 09:44
lber_types.h
1.43
KB
-rw-r--r--
2025-03-11 09:44
ldap.h
63.57
KB
-rw-r--r--
2025-03-11 09:44
ldap_cdefs.h
9.24
KB
-rw-r--r--
2025-03-11 09:44
ldap_features.h
1.77
KB
-rw-r--r--
2025-03-11 09:44
ldap_schema.h
9.23
KB
-rw-r--r--
2025-03-11 09:44
ldap_utf8.h
3.39
KB
-rw-r--r--
2025-03-11 09:44
ldif.h
4.58
KB
-rw-r--r--
2025-03-11 09:44
libaio.h
8.73
KB
-rw-r--r--
2019-11-13 13:59
libgen.h
1.35
KB
-rw-r--r--
2025-04-14 07:23
libintl.h
4.47
KB
-rw-r--r--
2025-04-14 07:23
limits.h
5.29
KB
-rw-r--r--
2025-04-14 07:23
link.h
7.05
KB
-rw-r--r--
2025-04-14 07:24
locale.h
7.49
KB
-rw-r--r--
2025-04-14 07:23
ltdl.h
5.58
KB
-rw-r--r--
2019-10-11 14:55
lzma.h
9.59
KB
-rw-r--r--
2018-04-29 15:10
magic.h
5.46
KB
-rw-r--r--
2024-04-06 14:44
malloc.h
5.96
KB
-rw-r--r--
2025-04-14 07:23
math.h
52.07
KB
-rw-r--r--
2025-04-14 07:23
mcheck.h
2.38
KB
-rw-r--r--
2025-04-14 07:23
memory.h
955
B
-rw-r--r--
2025-04-14 07:23
menu.h
11.91
KB
-rw-r--r--
2023-10-14 18:54
mntent.h
3.28
KB
-rw-r--r--
2025-04-14 07:23
monetary.h
1.76
KB
-rw-r--r--
2025-04-14 07:23
mqueue.h
3.67
KB
-rw-r--r--
2025-04-14 07:24
nc_tparm.h
4.1
KB
-rw-r--r--
2023-10-14 18:54
ncurses.h
97.29
KB
-rw-r--r--
2023-10-14 18:54
ncurses_dll.h
4.18
KB
-rw-r--r--
2023-10-14 18:54
ndbm.h
2.4
KB
-rw-r--r--
2022-10-08 13:22
netdb.h
27.44
KB
-rw-r--r--
2025-04-14 07:24
nl_types.h
1.71
KB
-rw-r--r--
2025-04-14 07:23
nss.h
1.83
KB
-rw-r--r--
2025-04-14 07:24
obstack.h
20.81
KB
-rw-r--r--
2025-04-14 07:23
panel.h
4.03
KB
-rw-r--r--
2023-10-14 18:54
paths.h
2.91
KB
-rw-r--r--
2025-04-14 07:23
pcre.h
30.97
KB
-rw-r--r--
2021-10-08 19:17
pcre2.h
43.75
KB
-rw-r--r--
2022-08-02 16:07
pcre2posix.h
5.67
KB
-rw-r--r--
2022-08-02 16:07
pcre_scanner.h
6.45
KB
-rw-r--r--
2021-10-08 19:17
pcre_stringpiece.h
6.16
KB
-rw-r--r--
2021-10-08 19:17
pcrecpp.h
25.91
KB
-rw-r--r--
2021-10-08 19:17
pcrecpparg.h
6.62
KB
-rw-r--r--
2021-10-08 19:17
pcreposix.h
5.32
KB
-rw-r--r--
2021-10-08 19:17
png.h
140.77
KB
-rw-r--r--
2019-10-12 00:44
pngconf.h
22.31
KB
-rw-r--r--
2019-10-12 00:44
pnglibconf.h
7.39
KB
-rw-r--r--
2019-10-12 00:44
poll.h
22
B
-rw-r--r--
2025-04-14 07:23
pr29.h
2.07
KB
-rw-r--r--
2019-10-13 16:55
printf.h
6.64
KB
-rw-r--r--
2025-04-14 07:23
proc_service.h
3.39
KB
-rw-r--r--
2025-04-14 07:24
profile.h
11.87
KB
-rw-r--r--
2025-03-13 12:14
pthread.h
40.3
KB
-rw-r--r--
2025-04-14 07:23
pty.h
1.53
KB
-rw-r--r--
2025-04-14 07:24
punycode.h
9.16
KB
-rw-r--r--
2019-10-13 16:55
pwd.h
6.01
KB
-rw-r--r--
2025-04-14 07:23
re_comp.h
962
B
-rw-r--r--
2025-04-14 07:23
regex.h
24.14
KB
-rw-r--r--
2025-04-14 07:23
regexp.h
1.41
KB
-rw-r--r--
2025-04-14 07:23
resolv.h
11.79
KB
-rw-r--r--
2025-04-14 07:24
sched.h
4.62
KB
-rw-r--r--
2025-04-14 07:23
search.h
5.1
KB
-rw-r--r--
2025-04-14 07:23
semaphore.h
2.34
KB
-rw-r--r--
2025-04-14 07:23
setjmp.h
3.58
KB
-rw-r--r--
2025-04-14 07:23
sgtty.h
1.31
KB
-rw-r--r--
2025-04-14 07:23
shadow.h
5.34
KB
-rw-r--r--
2025-04-14 07:23
signal.h
11.96
KB
-rw-r--r--
2025-04-14 07:23
slapi-plugin.h
37.45
KB
-rw-r--r--
2025-03-11 09:44
spawn.h
6.53
KB
-rw-r--r--
2025-04-14 07:23
stab.h
264
B
-rw-r--r--
2025-04-14 07:23
stdc-predef.h
2.24
KB
-rw-r--r--
2025-04-14 07:23
stdint.h
8.27
KB
-rw-r--r--
2025-04-14 07:23
stdio.h
29.46
KB
-rw-r--r--
2025-04-14 07:23
stdio_ext.h
2.73
KB
-rw-r--r--
2025-04-14 07:23
stdlib.h
34.82
KB
-rw-r--r--
2025-04-14 07:23
string.h
17.17
KB
-rw-r--r--
2025-04-14 07:23
stringprep.h
8.03
KB
-rw-r--r--
2019-10-13 16:55
strings.h
4.64
KB
-rw-r--r--
2025-04-14 07:23
syscall.h
25
B
-rw-r--r--
2025-04-14 07:23
sysexits.h
5.11
KB
-rw-r--r--
2025-04-14 07:23
syslog.h
24
B
-rw-r--r--
2025-04-14 07:23
tar.h
3.7
KB
-rw-r--r--
2025-04-14 07:23
term.h
40.22
KB
-rw-r--r--
2023-10-14 18:54
term_entry.h
8.55
KB
-rw-r--r--
2023-10-14 18:54
termcap.h
3.39
KB
-rw-r--r--
2023-10-14 18:54
termio.h
214
B
-rw-r--r--
2025-04-14 07:23
termios.h
3.51
KB
-rw-r--r--
2025-04-14 07:23
tgmath.h
30.75
KB
-rw-r--r--
2025-04-14 07:23
thread_db.h
15.65
KB
-rw-r--r--
2025-04-14 07:24
threads.h
6.5
KB
-rw-r--r--
2025-04-14 07:23
tic.h
13.32
KB
-rw-r--r--
2023-10-14 18:54
tiff.h
35.14
KB
-rw-r--r--
2024-11-05 01:55
tiffconf-64.h
3.35
KB
-rw-r--r--
2024-11-05 01:55
tiffconf.h
250
B
-rw-r--r--
2024-11-05 01:55
tiffio.h
22.68
KB
-rw-r--r--
2024-11-05 01:55
tiffio.hxx
1.66
KB
-rw-r--r--
2024-11-05 01:55
tiffvers.h
410
B
-rw-r--r--
2024-11-05 01:55
time.h
10.12
KB
-rw-r--r--
2025-04-14 07:23
tld.h
4.54
KB
-rw-r--r--
2019-10-13 16:55
ttyent.h
2.44
KB
-rw-r--r--
2025-04-14 07:23
uchar.h
1.95
KB
-rw-r--r--
2025-04-14 07:23
ucontext.h
1.99
KB
-rw-r--r--
2025-04-14 07:23
ulimit.h
1.55
KB
-rw-r--r--
2025-04-14 07:23
unctrl.h
3.03
KB
-rw-r--r--
2023-10-14 18:54
unistd.h
41.74
KB
-rw-r--r--
2025-04-14 07:23
utime.h
1.47
KB
-rw-r--r--
2025-04-14 07:23
utmp.h
3.15
KB
-rw-r--r--
2025-04-14 07:24
utmpx.h
4
KB
-rw-r--r--
2025-04-14 07:24
values.h
1.91
KB
-rw-r--r--
2025-04-14 07:23
verto-module.h
6.48
KB
-rw-r--r--
2022-10-08 07:49
verto.h
18.98
KB
-rw-r--r--
2022-10-08 07:49
wait.h
22
B
-rw-r--r--
2025-04-14 07:23
wchar.h
30.38
KB
-rw-r--r--
2025-04-14 07:23
wctype.h
5.42
KB
-rw-r--r--
2025-04-14 07:23
wordexp.h
2.44
KB
-rw-r--r--
2025-04-14 07:23
zconf.h
15.88
KB
-rw-r--r--
2023-10-11 22:02
zlib.h
94
KB
-rw-r--r--
2023-10-11 22:02
Save
Rename
/* * Copyright (c) 2013-2014 by Farsight Security, Inc. * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * */ /*! \file * \mainpage Introduction * * This is `fstrm`, a C implementation of the Frame Streams data transport * protocol. * * Frame Streams is a light weight, binary clean protocol that allows for the * transport of arbitrarily encoded data payload sequences with minimal framing * overhead -- just four bytes per data frame. Frame Streams does not specify an * encoding format for data frames and can be used with any data serialization * format that produces byte sequences, such as [Protocol Buffers], [XML], * [JSON], [MessagePack], [YAML], etc. Frame Streams can be used as both a * streaming transport over a reliable byte stream socket (TCP sockets, TLS * connections, `AF_UNIX` sockets, etc.) for data in motion as well as a file * format for data at rest. A "Content Type" header identifies the type of * payload being carried over an individual Frame Stream and allows cooperating * programs to determine how to interpret a given sequence of data payloads. * * `fstrm` is an optimized C implementation of Frame Streams that includes a * fast, lockless circular queue implementation and exposes library interfaces * for setting up a dedicated Frame Streams I/O thread and asynchronously * submitting data frames for transport from worker threads. It was originally * written to facilitate the addition of high speed binary logging to DNS * servers written in C using the [dnstap] log format. * * This is the API documentation for the `fstrm` library. For the project * hosting site, see <https://github.com/farsightsec/fstrm>. * * \authors Farsight Security, Inc. and the `fstrm` authors. * * \copyright 2013-2018. Licensed under the terms of the [MIT] license. * * [Protocol Buffers]: https://developers.google.com/protocol-buffers/ * [XML]: http://www.w3.org/TR/xml11/ * [JSON]: http://www.json.org/ * [MessagePack]: http://msgpack.org/ * [YAML]: http://www.yaml.org/ * [dnstap]: http://dnstap.info/ * [MIT]: https://opensource.org/licenses/MIT * * \page overview Library overview * * \section init Initializing the library * * `fstrm` has no global library state. In most cases, only a single * \ref fstrm_iothr library context object will be needed for the entire process, * which will implicitly create a background I/O serialization thread. This I/O * thread is bound to a particular output writer (for example, an `AF_UNIX` * socket) and is fully buffered -- submitted data frames will be accumulated in * an output buffer and periodically flushed, minimizing the number of system * calls that need to be performed. This frees worker threads from waiting for a * write() to complete. * * `fstrm` abstracts the actual I/O operations needed to read or write a byte * stream. File and socket I/O implementations are included in the library, but * if necessary `fstrm` can be extended to support new types of byte stream * transports. See the \ref fstrm_reader, \ref fstrm_writer, and \ref fstrm_rdwr * interfaces for details. * * The following code example shows the initialization of an `fstrm_iothr` * library context object connected to an \ref fstrm_file writer. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ const char *file_path = "/tmp/output.fs"; struct fstrm_file_options *fopt; struct fstrm_iothr *iothr; struct fstrm_writer *writer; fopt = fstrm_file_options_init(); fstrm_file_options_set_file_path(fopt, file_path); writer = fstrm_file_writer_init(fopt, NULL); if (!writer) { fprintf(stderr, "Error: fstrm_file_writer_init() failed.\n"); exit(EXIT_FAILURE); } iothr = fstrm_iothr_init(NULL, &writer); if (!iothr) { fprintf(stderr, "Error: fstrm_iothr_init() failed.\n"); exit(EXIT_FAILURE); } fstrm_file_options_destroy(&fopt); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Since the I/O operations are abstracted through the `fstrm_writer` interface, * the `writer` variable in the above example could instead have been * initialized with a completely different implementation. For example, * \ref fstrm_unix_writer objects can be initialized as follows: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ const char *socket_path = "/tmp/output.sock"; struct fstrm_writer *writer; struct fstrm_unix_writer_options *uwopt; uwopt = fstrm_unix_writer_options_init(); fstrm_unix_writer_options_set_socket_path(uwopt, socket_path); writer = fstrm_unix_writer_init(uwopt, NULL); if (!writer) { fprintf(stderr, "Error: fstrm_unix_writer_init() failed.\n"); exit(EXIT_FAILURE); } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section queue Getting an input queue * * After the `fstrm_iothr` object has been created with fstrm_iothr_init(), an * input queue handle can be obtained with the fstrm_iothr_get_input_queue() * function, which returns an `fstrm_iothr_queue` object. This function is * thread-safe and returns a unique queue each time it is called, up to the * number of queues specified by fstrm_iothr_options_set_num_input_queues(). * `fstrm_iothr_queue` objects belong to their parent `fstrm_iothr` object and * will be destroyed when the parent `fstrm_iothr` object is destroyed. * * The following code example shows a single `fstrm_iothr_queue` handle being * obtained from an already initialized `fstrm_iothr` library context object. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * struct fstrm_iothr_queue *ioq; ioq = fstrm_iothr_get_input_queue(iothr); if (!ioq) { fprintf(stderr, "Error: fstrm_iothr_get_input_queue() failed.\n"); exit(EXIT_FAILURE); } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section submit Submitting data frames * * Once the `fstrm_iothr` object has been created and an `fstrm_iothr_queue` * handle is available, data frames can be submitted for asynchronous writing * using the fstrm_iothr_submit() function. A callback is passed to this * function which will be invoked to deallocate the data frame once the I/O * thread has completed processing it. In the common case where the data frame * is dynamically allocated with `malloc()`, the deallocation callback must call * `free()`. fstrm_free_wrapper() is provided as a convenience function which * does this and can be specified as the `free_func` parameter to * fstrm_iothr_submit(). * * If space is available in the queue, fstrm_iothr_submit() will return * #fstrm_res_success, indicating that ownership of the memory allocation for the * data frame has passed from the caller to the library. The caller must not * reuse or deallocate the memory for the data frame after a successful call to * fstrm_iothr_submit(). * * Callers must check the return value of fstrm_iothr_submit(). If this function * fails, that is, it returns any result code other than #fstrm_res_success, the * caller must deallocate or otherwise dispose of memory allocated for the data * frame, in order to avoid leaking memory. fstrm_iothr_submit() can fail with * #fstrm_res_again if there is currently no space in the circular queue for an * additional frame, in which case a later call to fstrm_iothr_submit() with the * same parameters may succeed. However, if fstrm_iothr_submit() fails with * #fstrm_res_invalid, then there is a problem with the parameters and a later * call will not succeed. * * The following code example shows data frames containing a short sequence of * bytes being created and submitted repeatedly, with appropriate error * handling. Note that the data frames in this example intentionally contain * embedded unprintable characters, showing that Frame Streams is binary clean. * This example follows from the previous examples, where the `iothr` and `ioq` * variables have already been initialized. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * // 'ioq' is a struct fstrm_queue * const unsigned num_frames = 100; const uint8_t frame_template[] = { 'H', 'e', 'l', 'l', 'o', 0x00, 0x01, 0x02, 0x03, 'W', 'o', 'r', 'l', 'd', 0x04, 0x05, 0x06, 0x07, }; for (unsigned i = 0; i < num_frames; i++) { // Allocate a new frame from the template. uint8_t *frame = malloc(sizeof(frame_template)); if (!frame) break; memcpy(frame, frame_template, sizeof(frame_template)); // Submit the frame for writing. for (;;) { fstrm_res res; res = fstrm_iothr_submit(iothr, ioq, frame, sizeof(frame_template), fstrm_free_wrapper, NULL); if (res == fstrm_res_success) { // Frame successfully queued. break; } else if (res == fstrm_res_again) { // Queue is full. Try again in a busy loop. // Alternatively, if loss can be tolerated we // could free the frame here and break out of // the loop. continue; } else { // Permanent failure. free(frame); fputs("fstrm_iothr_submit() failed.\n", stderr); break; } } } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section shutdown Shutting down * * Calling fstrm_iothr_destroy() on the `fstrm_iothr` object will signal the I/O * thread to flush any outstanding data frames being written and will deallocate * all associated resources. This function is synchronous and does not return * until the I/O thread has terminated. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * fstrm_iothr_destroy(&iothr); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ #ifndef FSTRM_H #define FSTRM_H #ifdef __cplusplus extern "C" { #endif #include <sys/uio.h> #include <stddef.h> #include <stdint.h> /** * \defgroup fstrm_res fstrm_res * * Library result codes. * @{ */ /** * Result codes for functions. */ typedef enum { /** Success. */ fstrm_res_success, /** Failure. */ fstrm_res_failure, /** Resource temporarily unavailable. */ fstrm_res_again, /** Parameters were invalid. */ fstrm_res_invalid, /** The end of a stream has been reached. */ fstrm_res_stop, } fstrm_res; /**@}*/ struct fstrm_control; struct fstrm_file_options; struct fstrm_iothr; struct fstrm_iothr_options; struct fstrm_iothr_queue; struct fstrm_rdwr; struct fstrm_reader_options; struct fstrm_unix_writer_options; struct fstrm_writer; struct fstrm_writer_options; #include <fstrm/control.h> #include <fstrm/file.h> #include <fstrm/iothr.h> #include <fstrm/rdwr.h> #include <fstrm/reader.h> #include <fstrm/tcp_writer.h> #include <fstrm/unix_writer.h> #include <fstrm/writer.h> #ifdef __cplusplus } #endif #endif /* FSTRM_H */