blob: 1912ca8f9bb0b7ff08da13751ecb81ac176a0aa7 [file] [log] [blame]
Damien Miller834aeac2014-02-28 10:25:16 +11001# $OpenBSD: agent-ptrace.sh,v 1.2 2014/02/27 21:21:25 djm Exp $
Damien Miller8b9cde72003-01-22 17:53:16 +11002# Placed in the Public Domain.
3
4tid="disallow agent ptrace attach"
5
Tim Rice23ee3592003-09-11 22:32:17 -07006if have_prog uname ; then
Darren Tucker55697592003-09-04 13:55:25 +10007 case `uname` in
Darren Tuckerb17035f2004-08-29 20:33:07 +10008 AIX|CYGWIN*|OSF1)
Darren Tucker77d07e92003-09-04 22:06:16 +10009 echo "skipped (not supported on this platform)"
Darren Tucker55697592003-09-04 13:55:25 +100010 exit 0
11 ;;
12 esac
13fi
14
Tim Riceb7efb632003-09-12 11:20:32 -070015if have_prog gdb ; then
16 : ok
17else
Darren Tucker55697592003-09-04 13:55:25 +100018 echo "skipped (gdb not found)"
19 exit 0
20fi
21
Damien Miller6d6fcd12013-12-08 15:53:28 +110022if $OBJ/setuid-allowed ${SSHAGENT} ; then
23 : ok
24else
25 echo "skipped (${SSHAGENT} is mounted on a no-setuid filesystem)"
26 exit 0
27fi
28
Darren Tuckerea4c6702003-10-21 22:27:08 +100029if test -z "$SUDO" ; then
30 echo "skipped (SUDO not set)"
31 exit 0
32else
Darren Tuckerbe8a7712003-11-03 22:52:52 +110033 $SUDO chown 0 ${SSHAGENT}
34 $SUDO chgrp 0 ${SSHAGENT}
Darren Tucker2bdacad2003-10-21 23:12:37 +100035 $SUDO chmod 2755 ${SSHAGENT}
Darren Tuckerea4c6702003-10-21 22:27:08 +100036fi
37
Damien Miller8b9cde72003-01-22 17:53:16 +110038trace "start agent"
39eval `${SSHAGENT} -s` > /dev/null
40r=$?
41if [ $r -ne 0 ]; then
42 fail "could not start ssh-agent: exit code $r"
43else
44 # ls -l ${SSH_AUTH_SOCK}
45 gdb ${SSHAGENT} ${SSH_AGENT_PID} > ${OBJ}/gdb.out 2>&1 << EOF
46 quit
47EOF
Tim Rice6f917ad2014-01-28 10:26:25 -080048 r=$?
49 if [ $r -ne 0 ]; then
50 fail "gdb failed: exit code $r"
Damien Miller8b9cde72003-01-22 17:53:16 +110051 fi
Damien Millerfd3669e2011-01-17 11:20:18 +110052 egrep 'ptrace: Operation not permitted.|procfs:.*Permission denied.|ttrace.*Permission denied.|procfs:.*: Invalid argument.|Unable to access task ' >/dev/null ${OBJ}/gdb.out
Damien Miller8b9cde72003-01-22 17:53:16 +110053 r=$?
54 rm -f ${OBJ}/gdb.out
55 if [ $r -ne 0 ]; then
56 fail "ptrace succeeded?: exit code $r"
57 fi
58
59 trace "kill agent"
60 ${SSHAGENT} -k > /dev/null
61fi