X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=userv.git;a=blobdiff_plain;f=common.h;h=6b287da54dc7f833065bcfc8fc88ee1c5e01f569;hp=73e015275594688e67fb039c489d63d9c77cb0b6;hb=d237116707105a3ca6cf367a672bc5263cf7856d;hpb=464d71c37246e556de9ec05f7b97af834a5224ee diff --git a/common.h b/common.h index 73e0152..6b287da 100644 --- a/common.h +++ b/common.h @@ -2,7 +2,7 @@ * userv - common.h * definitions shared between client and daemon * - * Copyright (C)1996-1997 Ian Jackson + * Copyright (C)1996-1997,1999 Ian Jackson * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by @@ -43,18 +43,19 @@ static const unsigned char protocolchecksumversion[PCSUMSIZE]= { #ifndef PIPEFORMAT # define PIPEFORMAT "%lx.%lx.%x" # define PIPEPATTERN "[0-9a-f]*.[0-9a-f]*.*[0-9a-f]" -# define PIPEFORMATEXTEND (sizeof(long)*2*2+sizeof(int)*2+1) -# define PIPEMAXLEN (sizeof(PIPEFORMAT)+PIPEFORMATEXTEND) +# define PIPEFORMATEXTEND ((int)(sizeof(unsigned long)*2*2+(int)sizeof(int)*2+3)) +# define PIPEMAXLEN ((int)(sizeof(PIPEFORMAT)+PIPEFORMATEXTEND)) #endif #ifndef PIPEPATHFORMAT # define PIPEPATHFORMAT VARDIR "/" PIPEFORMAT -# define PIPEPATHMAXLEN (sizeof(PIPEPATHFORMAT)+PIPEFORMATEXTEND) +# define PIPEPATHMAXLEN ((int)(sizeof(PIPEPATHFORMAT)+PIPEFORMATEXTEND)) #endif #define MAX_ALLOW_FD 1024 #define MAX_GENERAL_STRING (1024*1024) #define MAX_OVERRIDE_LEN MAX_GENERAL_STRING +#define MAX_ERRMSG_STRING 4096 #define MAX_ARGSDEFVAR 4096 #define MAX_GIDS 1024 @@ -76,23 +77,25 @@ enum { struct opening_msg { unsigned long magic; unsigned char protocolchecksumversion[PCSUMSIZE]; - pid_t serverpid; + pid_t overlordpid, serverpid; }; struct request_msg { unsigned long magic; - pid_t clientpid; + pid_t clientpid; /* or -1 if no service is required and this was a version check */ int serviceuserlen; int servicelen; - int lognamelen; - int cwdlen; + int loginnamelen, spoofed; /* spoofed is 0 or 1 */ + int cwdlen, overridelen; uid_t callinguid; - int ngids, nreadfds, nwritefds, nargs, nvars, overridelen; + int ngids, nreadfds, nwritefds, nargs, nvars; /* Followed by: * serviceuserlen bytes for the service user (unterminated) * servicelen bytes for the service (unterminated) - * lognamelen bytes for the login name (unterminated) + * loginnamelen bytes for the login name (unterminated) * cwdlen bytes for the cwd (unterminated) + * overridelen bytes for the override data (with extra \n but unterminated), + * or nothing if overridelen==-1 * ngids gid_ts for the primary group and supplementary groups * nreadfds and then nwritefds ints for the file descriptors * for each of the nargs arguments @@ -115,10 +118,9 @@ struct progress_msg { struct { int status; } terminated; } data; /* follwed by variable-length part: - * for ok: nothing - * for errmsg: messagelen bytes for the error message (unterminated) - * unsigned long PROGRESS_MAGIC - * for terminated: nothing + * for ok, failed, terminated: nothing + * for errmsg: messagelen bytes for the error message (unterminated, no \n) + * unsigned long PROGRESS_ERRMSG_END_MAGIC */ };