File: isTrustedHost.c

package info (click to toggle)
lcgdm 1.8.2-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 14,044 kB
  • sloc: ansic: 149,126; sh: 13,441; perl: 11,498; python: 5,778; cpp: 5,113; sql: 1,805; makefile: 1,388; fortran: 113
file content (87 lines) | stat: -rw-r--r-- 2,122 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/*
 * Copyright (C) 2005-2008 by CERN/IT/GD/CT
 * All rights reserved
 */

#ifndef lint
static char sccsid[] = "@(#)$RCSfile: isTrustedHost.c,v $ $Revision: 1.8 $ $Date: 2008/01/31 11:41:39 $ CERN IT-GD/CT Jean-Philippe Baud";
#endif /* not lint */

#include <stdio.h>
#include <string.h>
#if defined(_WIN32)
#include <winsock2.h>
#else
#include <netdb.h>
#include <netinet/in.h>
#endif
#include "Castor_limits.h"
#include "Cnetdb.h"

#ifndef _WIN32
#if defined(_REENTRANT) || defined(_THREAD_SAFE)
#define strtok(X,Y) strtok_r(X,Y,&last)
#endif /* _REENTRANT || _THREAD_SAFE */
#endif /* _WIN32 */

extern int DLL_DECL CDoubleDnsLookup _PROTO((int, char *));

/* Check in configuration file if a given hostname
   is trusted for a given operation
   Example of configuration file entries:
   RFIOD	RTRUST	host1 host2
   DPNS		TRUST	host3 host4
 */

int DLL_DECL
isTrustedHost2 (char *hostname, char *localhost, char *localdomain, char *svc_name, char *perm)
{
	char fqn[CA_MAXHOSTNAMELEN+1];
	char *getconfent();
	int l;
#ifndef _WIN32
#if defined(_REENTRANT) || defined(_THREAD_SAFE)
	char *last = NULL;
#endif
#endif
	char *p;
	char *q;

	if (! hostname)
		return (0);
	if (localhost && strcmp (hostname, localhost) == 0)
		return (1);
	if ((p = getconfent (svc_name, perm, 1)) == NULL)
		return (0);
	l = strlen (localdomain);
	for (q = strtok (p, "\t "); q; q = strtok (NULL, "\t ")) {
		if (strcmp (hostname, q) == 0)
			return (1);
		if (strchr (q, '.'))
			continue;
		if (strlen (q) + l + 1 > CA_MAXHOSTNAMELEN)
			continue;
		sprintf (fqn, "%s.%s", q, localdomain);
		if (strcmp (hostname, fqn) == 0)
			return (1);
	}
	return (0);
}

/* Check in configuration file if a client connected on the socket s
   is trusted for a given operation
   Example of configuration file entries:
   RFIOD	RTRUST	host1 host2
   DPNS		TRUST	host3 host4
 */

int DLL_DECL
isTrustedHost (int s, char *localhost, char *localdomain, char *svc_name, char *perm)
{
	char hostname[CA_MAXHOSTNAMELEN+1];

	if (CDoubleDnsLookup (s, hostname))
		return (0);

	return (isTrustedHost2 (hostname, localhost, localdomain, svc_name, perm));
}