#include <u.h>
#include <libc.h>
#include <thread.h>
#include <bio.h>
#include <ip.h>
#include <libsec.h>
#include "dat.h"
#include "fns.h"

enum {
	AvpFlagV = 1<<7,
	AvpFlagM = 1<<6,

	AVPSHORTHDR = 8,
	AVPLONGHDR = 12,

	AvpUserName = 1,
	AvpUserPassword = 2,
};

typedef struct AVP {
	uchar code[4];
	uchar flags;
	uchar ln[3];
	uchar vendorid[4]; //optional, if V flag set
} AVP;

static int
buildAPV(uchar *b, int vid, int code, uchar*s, int l)
{
	int sz;
	AVP *a;
	uchar *p;

	a = (AVP*)b;
	hnputl(a->code, code);
	a->flags = AvpFlagM;
	if (vid != 0) {
		a->flags |= AvpFlagV;
		hnputl(a->vendorid, vid);
		p = b+AVPLONGHDR;
	} else {
		p = b+AVPSHORTHDR;
	}
	memcpy(p, s, l);
	sz = (p-b)+l;
	p += l;
	put24(a->ln, sz);
	while(sz%4 != 0){
		*p = 0;
		p ++;
		sz ++;
	}
	return sz;
}

void
doTTLSphase2(int fd)
{
	uchar buf[Pktlen], *p;
	int len, n;
	char pwdbuf[256];
	int pwdlen;
	
	
	syslog(0, logname, "phase2 fd=%d...", fd);

	if (fd < 0) {
		syslog(0, logname, "cannot do TTLSphase2: fd=%d < 0 ", fd);
		return;
	}

	// do PAP: send username, password, encoded as AVP
	len = 0;
	p = buf;

	n = buildAPV(p, 0, AvpUserName, (uchar*)myId, strlen(myId));
	len += n;
	p += n;
	
	memset(pwdbuf, 0, sizeof(pwdbuf));
	strcpy(pwdbuf, myPasswd);
	pwdlen=strlen(myPasswd);
	if (pwdlen%16 != 0)
		pwdlen += (16 - (pwdlen%16 ));
	
	n = buildAPV(p, 0, AvpUserPassword,  (uchar*)pwdbuf, pwdlen);
	len += n;
	p += n;

	USED(p);
	n = write(fd, buf, len);
	if (n < 0)
		print("doTTLSphase2 write tlsfd failed: %r\n");
	if (n != len)
		print("doTTLSphase2 write tlsfd ()n!=len: n=%d len=%d\n", n, len);
	if (debug) print("doTTLSphase2 written %d of %d\n", n, len);
	syslog(0, logname, "phase2 fd=%d ... data sent", fd);
}