4aa0a8fc65
interfaces (such as when you are part of a carp pool), and you run rpcbind -h to restrict which interfaces have rpc services, rpcbind can none-the-less return addresses that aren't in the -h list. This patch enforces the rule that when you specify -h on the command line, then services returned from rpcbind must be to one of the addresses listed in -h, or be a loopback address (since localhost is implicit when running -h). The root cause of this is the assumption in addrmerge that there can be only one interface that matches a given network IP address. This turns out not to be the case. To retain historical behavior, I didn't try to fix the routine to prefer the address that the request came into, since I didn't know the side effects that might cause in the normal case. My quick analysis suggests that it wouldn't be a problem, but since this code is tricky I opted for the more conservative patch of only restricting the reply when -h is in effect. Hence, this change will have no effect when you are running rpcbind without -h. Reviewed by: alfred@ Sponsored by: iX Systems MFC after: 2 weeks
154 lines
4.8 KiB
C
154 lines
4.8 KiB
C
/* $NetBSD: rpcbind.h,v 1.1 2000/06/03 00:47:21 fvdl Exp $ */
|
|
/* $FreeBSD$ */
|
|
|
|
/*
|
|
* Sun RPC is a product of Sun Microsystems, Inc. and is provided for
|
|
* unrestricted use provided that this legend is included on all tape
|
|
* media and as a part of the software program in whole or part. Users
|
|
* may copy or modify Sun RPC without charge, but are not authorized
|
|
* to license or distribute it to anyone else except as part of a product or
|
|
* program developed by the user.
|
|
*
|
|
* SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
|
|
* WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
|
|
* PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
|
|
*
|
|
* Sun RPC is provided with no support and without any obligation on the
|
|
* part of Sun Microsystems, Inc. to assist in its use, correction,
|
|
* modification or enhancement.
|
|
*
|
|
* SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
|
|
* INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
|
|
* OR ANY PART THEREOF.
|
|
*
|
|
* In no event will Sun Microsystems, Inc. be liable for any lost revenue
|
|
* or profits or other special, indirect and consequential damages, even if
|
|
* Sun has been advised of the possibility of such damages.
|
|
*
|
|
* Sun Microsystems, Inc.
|
|
* 2550 Garcia Avenue
|
|
* Mountain View, California 94043
|
|
*/
|
|
/*
|
|
* Copyright (c) 1986 - 1991 by Sun Microsystems, Inc.
|
|
*/
|
|
|
|
/* #ident "@(#)rpcbind.h 1.4 90/04/12 SMI" */
|
|
|
|
/*
|
|
* rpcbind.h
|
|
* The common header declarations
|
|
*/
|
|
|
|
#ifndef rpcbind_h
|
|
#define rpcbind_h
|
|
|
|
#ifdef PORTMAP
|
|
#include <rpc/pmap_prot.h>
|
|
#endif
|
|
#include <rpc/rpcb_prot.h>
|
|
|
|
/*
|
|
* Stuff for the rmtcall service
|
|
*/
|
|
struct encap_parms {
|
|
u_int32_t arglen;
|
|
char *args;
|
|
};
|
|
|
|
struct r_rmtcall_args {
|
|
u_int32_t rmt_prog;
|
|
u_int32_t rmt_vers;
|
|
u_int32_t rmt_proc;
|
|
int rmt_localvers; /* whether to send port # or uaddr */
|
|
char *rmt_uaddr;
|
|
struct encap_parms rmt_args;
|
|
};
|
|
|
|
extern int debugging;
|
|
extern int doabort;
|
|
extern int verboselog;
|
|
extern int insecure;
|
|
extern int oldstyle_local;
|
|
extern rpcblist_ptr list_rbl; /* A list of version 3 & 4 rpcbind services */
|
|
|
|
#ifdef PORTMAP
|
|
extern struct pmaplist *list_pml; /* A list of version 2 rpcbind services */
|
|
extern char *udptrans; /* Name of UDP transport */
|
|
extern char *tcptrans; /* Name of TCP transport */
|
|
extern char *udp_uaddr; /* Universal UDP address */
|
|
extern char *tcp_uaddr; /* Universal TCP address */
|
|
#endif
|
|
|
|
int add_bndlist(struct netconfig *, struct netbuf *);
|
|
bool_t is_bound(char *, char *);
|
|
char *mergeaddr(SVCXPRT *, char *, char *, char *);
|
|
struct netconfig *rpcbind_get_conf(char *);
|
|
|
|
void rpcbs_init(void);
|
|
void rpcbs_procinfo(rpcvers_t, rpcproc_t);
|
|
void rpcbs_set(rpcvers_t, bool_t);
|
|
void rpcbs_unset(rpcvers_t, bool_t);
|
|
void rpcbs_getaddr(rpcvers_t, rpcprog_t, rpcvers_t, char *, char *);
|
|
void rpcbs_rmtcall(rpcvers_t, rpcproc_t, rpcprog_t, rpcvers_t, rpcproc_t,
|
|
char *, rpcblist_ptr);
|
|
void *rpcbproc_getstat(void *, struct svc_req *, SVCXPRT *, rpcvers_t);
|
|
|
|
void rpcb_service_3(struct svc_req *, SVCXPRT *);
|
|
void rpcb_service_4(struct svc_req *, SVCXPRT *);
|
|
|
|
/* Common functions shared between versions */
|
|
void *rpcbproc_set_com(void *, struct svc_req *, SVCXPRT *, rpcvers_t);
|
|
void *rpcbproc_unset_com(void *, struct svc_req *, SVCXPRT *, rpcvers_t);
|
|
bool_t map_set(RPCB *, char *);
|
|
bool_t map_unset(RPCB *, char *);
|
|
void delete_prog(unsigned int);
|
|
void *rpcbproc_getaddr_com(RPCB *, struct svc_req *, SVCXPRT *, rpcvers_t,
|
|
rpcvers_t);
|
|
void *rpcbproc_gettime_com(void *, struct svc_req *, SVCXPRT *,
|
|
rpcvers_t);
|
|
void *rpcbproc_uaddr2taddr_com(void *, struct svc_req *,
|
|
SVCXPRT *, rpcvers_t);
|
|
void *rpcbproc_taddr2uaddr_com(void *, struct svc_req *, SVCXPRT *,
|
|
rpcvers_t);
|
|
int create_rmtcall_fd(struct netconfig *);
|
|
void rpcbproc_callit_com(struct svc_req *, SVCXPRT *, rpcvers_t,
|
|
rpcvers_t);
|
|
void my_svc_run(void);
|
|
|
|
void rpcbind_abort(void);
|
|
void reap(int);
|
|
void toggle_verboselog(int);
|
|
|
|
int check_access(SVCXPRT *, rpcproc_t, void *, unsigned int);
|
|
int check_callit(SVCXPRT *, struct r_rmtcall_args *, int);
|
|
void logit(int, struct sockaddr *, rpcproc_t, rpcprog_t, const char *);
|
|
int is_loopback(struct netbuf *);
|
|
|
|
#ifdef PORTMAP
|
|
extern void pmap_service(struct svc_req *, SVCXPRT *);
|
|
#endif
|
|
|
|
void write_warmstart(void);
|
|
void read_warmstart(void);
|
|
|
|
char *addrmerge(struct netbuf *caller, char *serv_uaddr, char *clnt_uaddr,
|
|
char *netid);
|
|
int listen_addr(const struct sockaddr *sa);
|
|
void network_init(void);
|
|
struct sockaddr *local_sa(int);
|
|
|
|
/* For different getaddr semantics */
|
|
#define RPCB_ALLVERS 0
|
|
#define RPCB_ONEVERS 1
|
|
|
|
/* To convert a struct sockaddr to IPv4 or IPv6 address */
|
|
#define SA2SIN(sa) ((struct sockaddr_in *)(sa))
|
|
#define SA2SINADDR(sa) (SA2SIN(sa)->sin_addr)
|
|
#ifdef INET6
|
|
#define SA2SIN6(sa) ((struct sockaddr_in6 *)(sa))
|
|
#define SA2SIN6ADDR(sa) (SA2SIN6(sa)->sin6_addr)
|
|
#endif
|
|
|
|
#endif /* rpcbind_h */
|