]> git.saurik.com Git - apple/configd.git/blame - get-network-info
configd-1061.0.2.tar.gz
[apple/configd.git] / get-network-info
CommitLineData
9de8ab86
A
1#!/bin/sh
2
3#
afb19109 4# Copyright © 2015-2019 Apple Inc.
9de8ab86
A
5#
6# get-network-info
7#
8# Collect network information.
9#
10
11PATH=/bin:/usr/bin:/sbin:/usr/sbin
12
13# __SETUP_ROUTINES_BEGIN__
14
15process_opts () {
16
17 for i in $ARGS
942cecd7
A
18 do
19 case "$i" in
20 -c)
21 COLLECT_CONFIGURATION_FILES="Y"
22 shift
23 ;;
24 -n)
25 COLLECT_NDF_INFO="Y"
26 shift
27 ;;
afb19109 28 -P)
43bfd57e
A
29 COLLECT_PCAP="N"
30 shift
31 ;;
942cecd7
A
32 -s)
33 COLLECT_SENSITIVE_INFO="Y"
34 shift
35 ;;
36 --)
37 shift
38 ;;
39 *)
40 REQUESTED_OUTDIR="${i}"
41 shift
42 ;;
43 esac
44 done
9de8ab86
A
45
46}
47
48set_root () {
49
50 PRIV=""
51 if [ ${EUID} -ne 0 ]; then
52 PRIV="sudo"
53 fi
54
55}
56
57#
58# Setup
59#
60setup () {
61
62 set_root
63 umask 077
64 cd "${REQUESTED_OUTDIR}"
65
66}
67
68# __SETUP_ROUTINES_END__
69
70
71# __COMMAND_ROUTINES_BEGIN__
72
afb19109
A
73#
74# mDNSResponder state dump
75# /usr/bin/dns-sd -O -stdout will print the state of mDNSResponder to STDOUT
76#
9de8ab86
A
77collect_state_dump_sensitive () {
78
afb19109
A
79 echo "`date +"%Y-%m-%d %H:%M:%S"`: collect_state_dump_sensitive" >> get-network-info.txt
80 ${PRIV} /usr/bin/dns-sd -O -stdout > mDNSResponder_state_dump.txt 2>&1
9de8ab86
A
81
82}
83
84#
85# network interface configuration
86#
87run_ifconfig () {
88
89 if [ ! -x /sbin/ifconfig ]; then
90 return
91 fi
92
afb19109 93 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_ifconfig" >> get-network-info.txt
9de8ab86
A
94 /sbin/ifconfig -a -L -b -m -r -v -v > ifconfig.txt 2>&1
95 if [ $? -ne 0 ]; then
96 /sbin/ifconfig -a > ifconfig.txt 2>&1
97 fi
98
99}
100
101#
102# network route configuration and statistics
103#
104run_netstat () {
105
106 if [ ! -x /usr/sbin/netstat ]; then
107 return
108 fi
109
afb19109 110 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_netstat" >> get-network-info.txt
9de8ab86
A
111 echo "#" > netstat.txt
112 echo "# netstat -n -r -a -l" >> netstat.txt
113 echo "#" >> netstat.txt
114 /usr/sbin/netstat -n -r -a -l >> netstat.txt 2>&1
115
116 echo "#" >> netstat.txt
afb19109 117 echo "# netstat -A -a -l -n -v -W" >> netstat.txt
9de8ab86 118 echo "#" >> netstat.txt
afb19109 119 /usr/sbin/netstat -A -a -l -n -v -W >> netstat.txt 2>&1
9de8ab86
A
120
121 echo "#" >> netstat.txt
122 echo "# netstat -s" >> netstat.txt
123 echo "#" >> netstat.txt
124 /usr/sbin/netstat -s >> netstat.txt 2>&1
125
942cecd7
A
126 echo "#" >> netstat.txt
127 echo "# netstat -rs" >> netstat.txt
128 echo "#" >> netstat.txt
129 /usr/sbin/netstat -rs >> netstat.txt 2>&1
130
9de8ab86
A
131 echo "#" >> netstat.txt
132 echo "# netstat -mmm" >> netstat.txt
133 echo "#" >> netstat.txt
134 /usr/sbin/netstat -mmm >> netstat.txt 2>&1
135
136 echo "#" >> netstat.txt
137 echo "# netstat -i -n -d" >> netstat.txt
138 echo "#" >> netstat.txt
139 /usr/sbin/netstat -i -n -d >> netstat.txt 2>&1
140
141 echo "#" >> netstat.txt
142 echo "# netstat -i -x R" >> netstat.txt
143 echo "#" >> netstat.txt
144 /usr/sbin/netstat -i -x R >> netstat.txt 2>&1
145
146 echo "#" >> netstat.txt
147 echo "# netstat -a -n -p mptcp" >> netstat.txt
148 echo "#" >> netstat.txt
149 /usr/sbin/netstat -anp mptcp >> netstat.txt 2>&1
150
151 echo "#" >> netstat.txt
152 echo "# netstat -s -p mptcp" >> netstat.txt
153 echo "#" >> netstat.txt
154 /usr/sbin/netstat -s -p mptcp >> netstat.txt 2>&1
155
156 echo "#" >> netstat.txt
157 echo "# netstat -g -n -s" >> netstat.txt
158 echo "#" >> netstat.txt
159 /usr/sbin/netstat -g -n -s >> netstat.txt 2>&1
160
161 if [ -x /sbin/ifconfig ]; then
162 for if in ${IF_LIST}
163 do
afb19109
A
164 echo "#" >> netstat.txt
165 echo "# netstat -s -I ${if}" >> netstat.txt
166 echo "#" >> netstat.txt
167 /usr/sbin/netstat -s -I ${if} >> netstat.txt 2>&1
168
9de8ab86
A
169 IF_INFO=`/sbin/ifconfig -v ${if}`
170 `echo $IF_INFO | grep -q TXSTART`
171 if [ $? -eq 0 ]; then
172 echo "#" >> netstat.txt
173 echo "# netstat -qq -I ${if}" >> netstat.txt
174 echo "#" >> netstat.txt
175 /usr/sbin/netstat -qq -I ${if} >> netstat.txt 2>&1
176 fi
afb19109 177
9de8ab86
A
178 `echo $IF_INFO | grep -q RXPOLL`
179 if [ $? -eq 0 ]; then
180 echo "#" >> netstat.txt
181 echo "# netstat -Q -I ${if}" >> netstat.txt
182 echo "#" >> netstat.txt
183 /usr/sbin/netstat -Q -I ${if} >> netstat.txt 2>&1
184 fi
185 done
186 fi
187
188}
189
942cecd7
A
190#
191# ndp
192#
9de8ab86
A
193run_ndp () {
194
195 if [ ! -x /usr/sbin/ndp ]; then
196 return
197 fi
198
afb19109 199 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_ndp" >> get-network-info.txt
9de8ab86
A
200 echo "#" > ndp-info.txt
201 echo "# ndp -n -a" >> ndp-info.txt
202 echo "#" >> ndp-info.txt
203 /usr/sbin/ndp -n -a >> ndp-info.txt 2>&1
204
205 echo "#" >> ndp-info.txt
206 echo "# ndp -n -p" >> ndp-info.txt
207 echo "#" >> ndp-info.txt
208 /usr/sbin/ndp -n -p >> ndp-info.txt 2>&1
209
210 echo "#" >> ndp-info.txt
211 echo "# ndp -n -r" >> ndp-info.txt
212 echo "#" >> ndp-info.txt
213 /usr/sbin/ndp -n -r >> ndp-info.txt 2>&1
214
215 if [ -x /sbin/ifconfig ]; then
216 for if in ${IF_LIST}
217 do
218 echo "#" >> ndp-info.txt
219 echo "# ndp -i ${if}" >> ndp-info.txt
220 echo "#" >> ndp-info.txt
221 /usr/sbin/ndp -i ${if} >> ndp-info.txt 2>&1
222 done
223 fi
224
225}
226
942cecd7
A
227#
228# arp
229#
9de8ab86
A
230run_arp () {
231
232 if [ ! -x /usr/sbin/arp ]; then
233 return
234 fi
235
afb19109 236 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_arp" >> get-network-info.txt
9de8ab86
A
237 echo "#" > arp-info.txt
238 echo "# arp -n -a" >> arp-info.txt
239 echo "#" >> arp-info.txt
240 /usr/sbin/arp -n -a >> arp-info.txt 2>&1
241
242}
243
244#
245# DHCP configuration
246#
247run_ipconfig () {
248
249 if [ ! -x /usr/sbin/ipconfig ]; then
250 return
251 fi
252
afb19109 253 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_ipconfig" >> get-network-info.txt
9de8ab86
A
254 for if in ${IF_LIST}
255 do
256 case ${if} in
942cecd7
A
257 lo* )
258 ;;
259 *)
9de8ab86
A
260 echo "#" >> ipconfig-info.txt
261 echo "# INTERFACE ${if}" >> ipconfig-info.txt
262 echo "#" >> ipconfig-info.txt
263
264 echo "DHCPv4 information:" >> ipconfig-info.txt
265
266 IPCONFIG_INFO=`/usr/sbin/ipconfig getpacket ${if}`
267 if [ "${IPCONFIG_INFO}" != "" ]; then
268 echo "${IPCONFIG_INFO}" >> ipconfig-info.txt
269 else
270 echo "not available" >> ipconfig-info.txt
271 fi
272
273 echo"" >> ipconfig-info.txt
274
275 echo "DHCPv6 information:" >> ipconfig-info.txt
276
277 IPCONFIG_INFO=`/usr/sbin/ipconfig getv6packet ${if}`
278 if [ "${IPCONFIG_INFO}" != "" ]; then
279 echo "${IPCONFIG_INFO}" >> ipconfig-info.txt
280 else
281 echo "not available" >> ipconfig-info.txt
282 fi
283
284 echo"" >> ipconfig-info.txt
285 ;;
286 esac
287 done
288
289}
290
291#
292# IPsec configuration
293#
294run_setkey () {
295
296 if [ ! -x /usr/sbin/setkey -o ! -x /usr/bin/perl ]; then
297 return
298 fi
299
afb19109
A
300 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_setkey" >> get-network-info.txt
301 echo "#" > ipsec.txt
302 echo "# setkey -D" >> ipsec.txt
303 echo "#" >> ipsec.txt
9de8ab86
A
304 ${PRIV} /usr/sbin/setkey -D \
305 | /usr/bin/perl -l -n -e '
306 if (/^(\s+[AE]:\s+\S+\s+)"?(.*)"?\s*$/) {
307 printf "%s[redacted]%s\n", $1, $3;
308 } else {
309 printf "%s\n", $_;
310 }
afb19109 311 ' >> ipsec.txt
9de8ab86 312
afb19109
A
313 echo "" >> ipsec.txt
314 echo "#" >> ipsec.txt
315 echo "# setkey -Pp -D" >> ipsec.txt
316 echo "#" >> ipsec.txt
317 ${PRIV} /usr/sbin/setkey -Pp -D >> ipsec.txt
9de8ab86
A
318
319 for CF in /var/run/racoon/*.conf
320 do
321 if [ ! -r "${CF}" ]; then
322 continue
323 fi
324
afb19109
A
325 echo "" >> ipsec.txt
326 echo "#" >> ipsec.txt
327 echo "# ${CF}" >> ipsec.txt
328 echo "#" >> ipsec.txt
9de8ab86
A
329 ${PRIV} cat ${CF} \
330 | /usr/bin/perl -l -n -e '
331 if (/^(\s+shared_secret\s+use\s+)"?([^\s;"]+)"?(.*)/) {
332 printf "%s[redacted]%s\n", $1, $3;
333 } else {
334 printf "%s\n", $_;
335 }
afb19109 336 ' >> ipsec.txt
9de8ab86
A
337 done
338
339}
340
1ef45fa4
A
341#
342# skywalk configuration and statistics
343#
344run_skywalk () {
345
346 if [ ! -x /usr/sbin/skywalkctl ]; then
347 return
348 fi
349
afb19109 350 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_skywalk" >> get-network-info.txt
1ef45fa4 351 echo "#" > skywalk.txt
4f125ff5 352 echo "# skywalkctl show" >> skywalk.txt
1ef45fa4 353 echo "#" >> skywalk.txt
4f125ff5 354 /usr/sbin/skywalkctl show >> skywalk.txt 2>&1
1ef45fa4
A
355
356 echo "#" >> skywalk.txt
4f125ff5 357 echo "# skywalkctl flow -n" >> skywalk.txt
1ef45fa4 358 echo "#" >> skywalk.txt
4f125ff5 359 /usr/sbin/skywalkctl flow -n >> skywalk.txt 2>&1
1ef45fa4
A
360
361 echo "#" >> skywalk.txt
4f125ff5 362 echo "# skywalkctl flow-route -n" >> skywalk.txt
1ef45fa4 363 echo "#" >> skywalk.txt
4f125ff5
A
364 /usr/sbin/skywalkctl flow-route -n >> skywalk.txt 2>&1
365
366 echo "#" >> skywalk.txt
367 echo "# skywalkctl flow-switch" >> skywalk.txt
368 echo "#" >> skywalk.txt
369 /usr/sbin/skywalkctl flow-switch >> skywalk.txt 2>&1
370
371 echo "#" >> skywalk.txt
372 echo "# skywalkctl flow-owner" >> skywalk.txt
373 echo "#" >> skywalk.txt
374 /usr/sbin/skywalkctl flow-owner >> skywalk.txt 2>&1
375
376 echo "#" >> skywalk.txt
377 echo "# skywalkctl flow-adv" >> skywalk.txt
378 echo "#" >> skywalk.txt
379 /usr/sbin/skywalkctl flow-adv >> skywalk.txt 2>&1
1ef45fa4
A
380
381 echo "#" >> skywalk.txt
382 echo "# skywalkctl netstat -s" >> skywalk.txt
383 echo "#" >> skywalk.txt
384 /usr/sbin/skywalkctl netstat -s >> skywalk.txt 2>&1
385
386 echo "#" >> skywalk.txt
387 echo "# skywalkctl netstat -s --global" >> skywalk.txt
388 echo "#" >> skywalk.txt
389 /usr/sbin/skywalkctl netstat -s --global >> skywalk.txt 2>&1
390
391 echo "#" >> skywalk.txt
4f125ff5 392 echo "# skywalkctl interface" >> skywalk.txt
1ef45fa4 393 echo "#" >> skywalk.txt
4f125ff5 394 /usr/sbin/skywalkctl interface >> skywalk.txt 2>&1
1ef45fa4
A
395
396 echo "#" >> skywalk.txt
4f125ff5 397 echo "# skywalkctl channel" >> skywalk.txt
1ef45fa4 398 echo "#" >> skywalk.txt
4f125ff5 399 /usr/sbin/skywalkctl channel >> skywalk.txt 2>&1
1ef45fa4
A
400
401 echo "#" >> skywalk.txt
4f125ff5 402 echo "# skywalkctl provider -D" >> skywalk.txt
1ef45fa4 403 echo "#" >> skywalk.txt
4f125ff5 404 /usr/sbin/skywalkctl provider -D >> skywalk.txt 2>&1
1ef45fa4
A
405
406 echo "#" >> skywalk.txt
407 echo "# skywalkctl netns -a" >> skywalk.txt
408 echo "#" >> skywalk.txt
409 /usr/sbin/skywalkctl netns -a >> skywalk.txt 2>&1
410
411 echo "#" >> skywalk.txt
412 echo "# skywalkctl memory" >> skywalk.txt
413 echo "#" >> skywalk.txt
414 /usr/sbin/skywalkctl memory >> skywalk.txt 2>&1
415
416}
417
418#
419# skywalk configuration and statistics
420#
421run_nettop () {
422
423 if [ ! -x /usr/bin/nettop ]; then
424 return
425 fi
426
afb19109 427 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_nettop" >> get-network-info.txt
1ef45fa4 428 echo "#" > nettop.txt
afb19109 429 echo "# nettop -n -l 1" >> nettop.txt
1ef45fa4 430 echo "#" >> nettop.txt
afb19109 431 /usr/bin/nettop -n -l 1 >> nettop.txt 2>&1
1ef45fa4
A
432
433}
434
9de8ab86
A
435#
436# Network preferences
437#
438collect_configuration_files () {
439
afb19109 440 echo "`date +"%Y-%m-%d %H:%M:%S"`: collect_configuration_files" >> get-network-info.txt
9de8ab86
A
441 for f in \
442 /Library/Preferences/com.apple.networkextension.plist \
443 /Library/Preferences/com.apple.networkextension.control.plist \
444 /Library/Preferences/com.apple.networkextension.necp.plist \
1ef45fa4 445 /Library/Preferences/com.apple.networkextension.cache.plist \
f715d946 446 /Library/Preferences/com.apple.networkextension.uuidcache.plist \
9de8ab86
A
447 /Library/Preferences/SystemConfiguration/com.apple.nat.plist \
448 /Library/Preferences/SystemConfiguration/com.apple.RemoteAccessServers.plist \
449 /Library/Preferences/SystemConfiguration/com.apple.smb.server.plist \
450 /Library/Preferences/com.apple.mDNSResponder.plist \
451 /Library/Preferences/SystemConfiguration/NetworkInterfaces.plist \
452 /Library/Preferences/SystemConfiguration/preferences.plist \
453
454 do
455 if [ -e "${f}" ]; then
456 b="`basename ${f}`"
afb19109 457 cat "${f}" > "${b}" 2>&1
9de8ab86
A
458 fi
459 done
460
461 if [ -e /etc/resolv.conf ]; then
afb19109 462 cat /etc/resolv.conf > etc-resolv-conf.txt 2>&1
9de8ab86
A
463 fi
464 if [ -e /var/run/resolv.conf ]; then
afb19109 465 cat /var/run/resolv.conf > var-run-resolv-conf.txt 2>&1
9de8ab86
A
466 fi
467 if [ -e /etc/resolver ]; then
afb19109 468 tar -c -H /etc/resolver > etc-resolver.tar 2>/dev/null
9de8ab86
A
469 fi
470}
471
942cecd7
A
472#
473# VPN
474#
9de8ab86
A
475collect_vpn_logs () {
476
afb19109 477 echo "`date +"%Y-%m-%d %H:%M:%S"`: collect_vpn_logs" >> get-network-info.txt
9de8ab86
A
478 for f in \
479 /var/log/vpnd.log \
480 /var/log/racoon.log \
481
482 do
483 if [ -e "${f}" ]; then
484 b="`basename ${f}`"
afb19109 485 ${PRIV} cat "${f}" > "${b}".txt 2>&1
9de8ab86
A
486 fi
487 done
488}
489
942cecd7
A
490#
491# Policy
492#
493run_neutil () {
494
495 if [ ! -x /usr/local/bin/neutil ]; then
496 return
497 fi
498
afb19109 499 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_neutil" >> get-network-info.txt
1ef45fa4 500 (
afb19109
A
501 echo "#" > necp.txt
502 echo "# neutil policy dump" >> necp.txt
503 echo "#" >> necp.txt
504 /usr/local/bin/neutil policy dump >> necp.txt 2>&1
1ef45fa4 505
afb19109
A
506 echo "#" > network-agents.txt
507 echo "# neutil agent dump" >> network-agents.txt
508 echo "#" >> network-agents.txt
509 /usr/local/bin/neutil agent dump >> network-agents.txt 2>&1
4f125ff5
A
510
511 # Generates a default-level log message containing the current file handles that UserEventAgent has
512 /usr/local/bin/neutil session log-file-handles
513 sleep 1 &
1ef45fa4 514 ) &
942cecd7
A
515}
516
517#
518# Path
519#
520run_network_test () {
521
522 if [ ! -x /usr/local/bin/network_test ]; then
523 return
524 fi
525
afb19109
A
526 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_network_test" >> get-network-info.txt
527 /usr/local/bin/network_test path_watcher -dump > nw_path.txt 2>&1
942cecd7
A
528
529}
530
9de8ab86
A
531#
532# Network, DNS, Proxy, Reachability, Cache information
533#
534run_scutil () {
535
536 if [ ! -x /usr/sbin/scutil ]; then
537 return
538 fi
539
afb19109
A
540 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_scutil" >> get-network-info.txt
541 echo "#" > network-information.txt
542 echo "# scutil -d -v --nwi" >> network-information.txt
543 echo "#" >> network-information.txt
544 /usr/sbin/scutil -d -v --nwi >> network-information.txt 2>&1
9de8ab86
A
545 for if in ${IF_LIST}
546 do
afb19109
A
547 echo "" >> network-information.txt
548 echo "#" >> network-information.txt
549 echo "# scutil --nwi ${if}" >> network-information.txt
550 echo "#" >> network-information.txt
551 scutil --nwi ${if} >> network-information.txt 2>&1
9de8ab86
A
552 done
553
afb19109
A
554 echo "#" > dns-configuration.txt
555 echo "# scutil -d -v --dns" >> dns-configuration.txt
556 echo "#" >> dns-configuration.txt
557 /usr/sbin/scutil -d -v --dns >> dns-configuration.txt 2>&1
9de8ab86 558
afb19109
A
559 echo "#" > proxy-configuration.txt
560 echo "# scutil -d -v --proxy" >> proxy-configuration.txt
561 echo "#" >> proxy-configuration.txt
562 /usr/sbin/scutil -d -v --proxy >> proxy-configuration.txt 2>&1
9de8ab86 563
afb19109
A
564 echo "#" > reachability-info.txt
565 echo '# scutil -d -v -r www.apple.com' >> reachability-info.txt
566 echo "#" >> reachability-info.txt
567 /usr/sbin/scutil -d -v -r www.apple.com >> reachability-info.txt 2>&1
9de8ab86 568
afb19109
A
569 echo "#" >> reachability-info.txt
570 echo '# scutil -d -v -r 0.0.0.0' >> reachability-info.txt
571 echo "#" >> reachability-info.txt
572 /usr/sbin/scutil -d -v -r 0.0.0.0 >> reachability-info.txt 2>&1
9de8ab86 573
afb19109
A
574 echo "#" >> reachability-info.txt
575 echo '# scutil -d -v -r 169.254.0.0' >> reachability-info.txt
576 echo "#" >> reachability-info.txt
577 /usr/sbin/scutil -d -v -r 169.254.0.0 >> reachability-info.txt 2>&1
942cecd7 578
afb19109
A
579 echo "#" > nc-info.txt
580 echo '# scutil --nc list' >> nc-info.txt
581 echo "#" >> nc-info.txt
582 /usr/sbin/scutil --nc list >> nc-info.txt 2>&1
942cecd7 583
afb19109 584 /usr/sbin/scutil -p --snapshot SCDynamicStore.plist 2>&1
9de8ab86
A
585
586}
587
942cecd7
A
588#
589# route
590#
9de8ab86
A
591run_route () {
592
593 if [ ! -x /sbin/route ]; then
594 return
595 fi
596
afb19109
A
597 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_route" >> get-network-info.txt
598 echo "#" > route-info.txt
599 echo '# route -n -v get www.apple.com' >> route-info.txt
600 echo "#" >> route-info.txt
601 /sbin/route -n -v get www.apple.com >> route-info.txt 2>&1
9de8ab86 602
afb19109
A
603 echo "#" >> route-info.txt
604 echo '# route -n -v get 0.0.0.0' >> route-info.txt
605 echo "#" >> route-info.txt
606 /sbin/route -n -v get 0.0.0.0 >> route-info.txt 2>&1
9de8ab86
A
607
608}
609
942cecd7
A
610#
611# dig
612#
9de8ab86
A
613run_dig () {
614
615 if [ ! -x /usr/bin/dig -o ! -f /etc/resolv.conf ]; then
616 return
617 fi
618
afb19109
A
619 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_dig" >> get-network-info.txt
620 echo "#" > dig-info.txt
621 echo '# dig -t any -c any www.apple.com' >> dig-info.txt
622 echo "#" >> dig-info.txt
623 /usr/bin/dig +time=2 -t any -c any www.apple.com >> dig-info.txt 2>/dev/null
9de8ab86
A
624
625}
626
627#
942cecd7 628# hostname
9de8ab86
A
629#
630run_hostname () {
631
632 if [ ! -x /bin/hostname ]; then
633 return
634 fi
635
afb19109
A
636 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_hostname" >> get-network-info.txt
637 /bin/hostname > hostname.txt 2>&1
9de8ab86
A
638
639}
640
942cecd7
A
641#
642# lsof
643#
644run_lsof () {
645
646 if [ ! -x /usr/sbin/lsof ]; then
647 return
648 fi
649
afb19109
A
650 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_lsof" >> get-network-info.txt
651 ${PRIV} /usr/sbin/lsof +c 0 -X -n -O -P -T q > lsof.txt 2>&1 &
942cecd7
A
652 LSOF_PID=$!
653 # start a watchdog for lsof
654 (
655 WAIT_TIME=5
656 while [ $WAIT_TIME -gt 0 ]
657 do
afb19109 658 ${PRIV} kill -0 ${LSOF_PID} 2>/dev/null
942cecd7
A
659 if [ $? -eq 0 ]; then
660 # lsof is [still] gathering data...
661 sleep 1
662 WAIT_TIME=$((WAIT_TIME - 1))
663 continue
664 fi
665
666 # lsof completed gathering data
667 break
668 done
669
670 if [ $WAIT_TIME -eq 0 ]; then
671 # lsof timed out
afb19109 672 ${PRIV} kill ${LSOF_PID} 2>/dev/null
942cecd7
A
673 fi
674 ) &
675
676}
677
afb19109
A
678#
679# sysctl
680#
681run_sysctl () {
682
683 if [ ! -x /usr/sbin/sysctl ]; then
684 return
685 fi
686
687 echo "`date +"%Y-%m-%d %H:%M:%S"`: run_sysctl" >> get-network-info.txt
688 ${PRIV} /usr/sbin/sysctl -a > sysctl.txt 2>&1 &
689
690}
691
43bfd57e 692start_pcap() {
43bfd57e
A
693 #
694 # collect a packet capture if netdiagnose is available
695 #
696 if [ -x /usr/local/bin/netdiagnose ]; then
afb19109 697 echo "`date +"%Y-%m-%d %H:%M:%S"`: start_pcap" >> get-network-info.txt
1ef45fa4 698 trap stop_pcap SIGINT
afb19109 699 /usr/local/bin/netdiagnose -p "${REQUESTED_OUTDIR}" start sysdiagpcap 2>&1 1>/dev/null
43bfd57e
A
700 PCAP_STARTED=1
701 fi
702}
703
704stop_pcap () {
705 if [ ${PCAP_STARTED} -ne 0 ]; then
1ef45fa4 706 trap '' SIGINT
afb19109
A
707 /usr/local/bin/netdiagnose stop sysdiagpcap 2>&1 1>/dev/null
708 echo "`date +"%Y-%m-%d %H:%M:%S"`: stop_pcap done" >> get-network-info.txt
43bfd57e
A
709 fi
710}
711
942cecd7
A
712collect_ndf_info () {
713 run_lsof
afb19109 714 run_sysctl
942cecd7
A
715}
716
9de8ab86 717collect_sensitive_info () {
43bfd57e
A
718
719 if [ "${COLLECT_PCAP}" == "Y" ]; then
720 start_pcap
721 fi
722
9de8ab86
A
723 collect_state_dump_sensitive
724 run_ndp
725 run_arp
942cecd7 726 run_neutil
1ef45fa4 727 run_nettop
942cecd7 728 run_network_test
9de8ab86
A
729}
730
731collect_info () {
942cecd7
A
732
733 if [ "${COLLECT_NDF_INFO}" == "Y" ]; then
734 collect_ndf_info
735 fi
9de8ab86
A
736
737 if [ "${COLLECT_SENSITIVE_INFO}" == "Y" ]; then
738 collect_sensitive_info
739 fi
740
741 run_scutil
742 run_dig
743 run_ifconfig
744 run_netstat
745 run_ipconfig
746 run_setkey
1ef45fa4 747 run_skywalk
9de8ab86
A
748 collect_vpn_logs
749 run_route
750 run_hostname
751
752 if [ "${COLLECT_CONFIGURATION_FILES}" == "Y" ]; then
753 collect_configuration_files
754 fi
43bfd57e
A
755
756 stop_pcap
9de8ab86
A
757}
758
759# __COMMAND_ROUTINES_END__
760
761# __HELPER_ROUTINES_BEGIN__
762
763usage () {
764
942cecd7 765 echo "Usage: get-network-info [-c] [-n] [-s] <info-directory>"
9de8ab86 766 echo " -c collects system configuration files"
942cecd7 767 echo " -n collects NDF information (lsof)"
43bfd57e 768 echo " -P do not collect a packet capture"
942cecd7 769 echo " -s collects sensitive information (ARP/NDP/mDNS cache)"
9de8ab86
A
770 echo " <info-directory> path to directory where all the information will be collected"
771
772}
773
774is_outdir_valid () {
775
1ef45fa4 776 if [ "${REQUESTED_OUTDIR}" = "" ]; then
9de8ab86
A
777 usage
778 exit 1
779 fi
780
1ef45fa4
A
781 if [ ! -d ${REQUESTED_OUTDIR} ]; then
782 echo "${REQUESTED_OUTDIR} does not exist"
783 exit 1
784 fi
785
9de8ab86
A
786 if [ ! -w ${REQUESTED_OUTDIR} ]; then
787 echo "${REQUESTED_OUTDIR} is write-protected"
788 exit 1
789 fi
790}
791
792#
793# Collect most used command output to be used later
794#
795optimize () {
796
797 if [ ! -x /sbin/ifconfig ]; then
798 return
799 fi
800
801 IF_LIST=`/sbin/ifconfig -l`
802
803}
804
805init_globals () {
806 REQUESTED_OUTDIR=""
807 COLLECT_SENSITIVE_INFO=""
808 COLLECT_CONFIGURATION_FILES=""
43bfd57e
A
809 COLLECT_PCAP="Y"
810 PCAP_STARTED=0
811
9de8ab86
A
812}
813
814# __HELPER_ROUTINES_END__
815
816#
817# __MAIN__
818#
43bfd57e 819ARGS=`getopt cnPs $*`
9de8ab86
A
820if [ $? != 0 ]; then
821 usage
822 exit 1
823fi
824
825init_globals
826process_opts
827is_outdir_valid
828setup
829optimize
830collect_info
831wait
832
9de8ab86 833exit 0