[BACK]Return to cvsd.h CVS log [TXT][DIR] Up to [local] / src / usr.bin / cvs

File: [local] / src / usr.bin / cvs / Attic / cvsd.h (download)

Revision 1.2, Sun Jul 25 03:29:35 2004 UTC (19 years, 10 months ago) by jfb
Branch: MAIN
Changes since 1.1: +44 -10 lines

* rework on the child API, still needs more functionality
* move the ACL parsing code into the more general conf.y, which handles
  parsing of the whole configuration file

/*	$OpenBSD: cvsd.h,v 1.2 2004/07/25 03:29:35 jfb Exp $	*/
/*
 * Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org>
 * All rights reserved. 
 *
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions 
 * are met: 
 *
 * 1. Redistributions of source code must retain the above copyright 
 *    notice, this list of conditions and the following disclaimer. 
 * 2. The name of the author may not be used to endorse or promote products
 *    derived from this software without specific prior written permission. 
 *
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
 * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 */

#ifndef CVSD_H
#define CVSD_H

#include <sys/types.h>
#include <sys/queue.h>
#include <sys/stat.h>
#include <sys/socket.h>

#include <netinet/in.h>

#include <pwd.h>
#include <signal.h>

#include "cvs.h"

#define CVSD_USER   "_cvsd"
#define CVSD_GROUP  "_cvsd"
#define CVSD_CONF   "/etc/cvsd.conf"

#define CVSD_CHILD_DEFMIN    3
#define CVSD_CHILD_DEFMAX    5



#define CVSD_FPERM  (S_IRUSR | S_IWUSR)
#define CVSD_DPERM  (S_IRWXU)


/* requests */
#define CVSD_MSG_GETUID    1
#define CVSD_MSG_GETUNAME  2
#define CVSD_MSG_GETGID    3
#define CVSD_MSG_GETGNAME  4
#define CVSD_MSG_PASSFD    5   /* server passes client file descriptor */
#define CVSD_MSG_SETIDLE   6   /* client has no further processing to do */

/* replies */
#define CVSD_MSG_UID       128
#define CVSD_MSG_UNAME     129
#define CVSD_MSG_GID       130
#define CVSD_MSG_GNAME     131

#define CVSD_MSG_SHUTDOWN  253
#define CVSD_MSG_OK        254
#define CVSD_MSG_ERROR     255

#define CVSD_MSG_MAXLEN    256


#define CVSD_SET_ROOT        1
#define CVSD_SET_CHMIN       2
#define CVSD_SET_CHMAX       3
#define CVSD_SET_ADDR        4
#define CVSD_SET_SOCK        5


#define CVSD_ST_UNKNOWN      0
#define CVSD_ST_IDLE         1
#define CVSD_ST_BUSY         2



/* message structure to pass data between the parent and the chrooted child */
struct cvsd_msg {
	u_int8_t  cm_type;
	u_int8_t  cm_len;    /* length of message data in bytes */
};


struct cvsd_child {
	pid_t  ch_pid;
	int    ch_sock;
	u_int  ch_state;

	TAILQ_ENTRY(cvsd_child) ch_list;
};


struct cvsd_addr {
	sa_family_t ca_fam;
	union {
		struct sockaddr_in *sin;
		struct sockaddr_in6 *sin6;
	} ca_addr;
};



extern volatile sig_atomic_t running;
extern volatile sig_atomic_t restart;




int                cvsd_set        (int, ...);
int                cvsd_checkperms (const char *);
int                cvsd_child_fork (struct cvsd_child **);
struct cvsd_child* cvsd_child_get  (void);
int                cvsd_child_reap (struct cvsd_child *);

/* from fdpass.c */
int   cvsd_sendfd  (int, int);
int   cvsd_recvfd  (int);


/* from conf.y */
int    cvs_conf_read (const char *);
u_int  cvs_acl_eval  (struct cvs_op *);

/* from msg.c */
int    cvsd_sendmsg (int, u_int, const void *, size_t);
int    cvsd_recvmsg (int, u_int *, void *, size_t *);

#endif /* CVSD_H */