summaryrefslogtreecommitdiff
path: root/sys/src/cmd/ssh/authtis.c
diff options
context:
space:
mode:
authorTaru Karttunen <taruti@taruti.net>2011-03-30 15:46:40 +0300
committerTaru Karttunen <taruti@taruti.net>2011-03-30 15:46:40 +0300
commite5888a1ffdae813d7575f5fb02275c6bb07e5199 (patch)
treed8d51eac403f07814b9e936eed0c9a79195e2450 /sys/src/cmd/ssh/authtis.c
Import sources from 2011-03-30 iso image
Diffstat (limited to 'sys/src/cmd/ssh/authtis.c')
-rwxr-xr-xsys/src/cmd/ssh/authtis.c65
1 files changed, 65 insertions, 0 deletions
diff --git a/sys/src/cmd/ssh/authtis.c b/sys/src/cmd/ssh/authtis.c
new file mode 100755
index 000000000..f922e02af
--- /dev/null
+++ b/sys/src/cmd/ssh/authtis.c
@@ -0,0 +1,65 @@
+#include "ssh.h"
+
+static int
+authtisfn(Conn *c)
+{
+ int fd, n;
+ char *chal, resp[256];
+ Msg *m;
+
+ if(!c->interactive)
+ return -1;
+
+ debug(DBG_AUTH, "try TIS\n");
+ sendmsg(allocmsg(c, SSH_CMSG_AUTH_TIS, 0));
+
+ m = recvmsg(c, -1);
+ switch(m->type){
+ default:
+ badmsg(m, SSH_SMSG_AUTH_TIS_CHALLENGE);
+ case SSH_SMSG_FAILURE:
+ free(m);
+ return -1;
+ case SSH_SMSG_AUTH_TIS_CHALLENGE:
+ break;
+ }
+
+ chal = getstring(m);
+ free(m);
+
+ if((fd = open("/dev/cons", ORDWR)) < 0)
+ error("can't open console");
+
+ fprint(fd, "TIS Authentication\n%s", chal);
+ n = read(fd, resp, sizeof resp-1);
+ if(n < 0)
+ resp[0] = '\0';
+ else
+ resp[n] = '\0';
+
+ if(resp[0] == 0 || resp[0] == '\n')
+ return -1;
+
+ m = allocmsg(c, SSH_CMSG_AUTH_TIS_RESPONSE, 4+strlen(resp));
+ putstring(m, resp);
+ sendmsg(m);
+
+ m = recvmsg(c, -1);
+ switch(m->type){
+ default:
+ badmsg(m, 0);
+ case SSH_SMSG_SUCCESS:
+ free(m);
+ return 0;
+ case SSH_SMSG_FAILURE:
+ free(m);
+ return -1;
+ }
+}
+
+Auth authtis =
+{
+ SSH_AUTH_TIS,
+ "tis",
+ authtisfn,
+};