git: 9front

ref: 2863f009cc6ee4ffdfbea8c791ffc1b70dceeb97
dir: /sys/src/libauth/auth_chuid.c/

View raw version
#include <u.h>
#include <libc.h>
#include <auth.h>

/*
 *  become the authenticated user
 */
int
auth_chuid(AuthInfo *ai, char *ns)
{
	int rv, fd;

	if(ai == nil || ai->cap == nil || ai->cap[0] == 0){
		werrstr("no capability");
		return -1;
	}

	/* change uid */
	fd = open("#¤/capuse", OWRITE|OCEXEC);
	if(fd < 0){
		werrstr("opening #¤/capuse: %r");
		return -1;
	}
	rv = write(fd, ai->cap, strlen(ai->cap));
	close(fd);
	if(rv < 0){
		werrstr("writing %s to #¤/capuse: %r", ai->cap);
		return -1;
	}

	/* get a link to factotum as new user */
	fd = open("/srv/factotum", ORDWR);
	if(fd >= 0){
		if(mount(fd, -1, "/mnt", MREPL, "") == -1)
			close(fd);
	}

	/* set up new namespace */
	return newns(ai->cuid, ns);
}