My Project
gridsite.h
Go to the documentation of this file.
1/*
2 Copyright (c) 2002-10, Andrew McNab, University of Manchester
3 All rights reserved.
4
5 Redistribution and use in source and binary forms, with or
6 without modification, are permitted provided that the following
7 conditions are met:
8
9 o Redistributions of source code must retain the above
10 copyright notice, this list of conditions and the following
11 disclaimer.
12 o Redistributions in binary form must reproduce the above
13 copyright notice, this list of conditions and the following
14 disclaimer in the documentation and/or other materials
15 provided with the distribution.
16
17 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
18 CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
19 INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
20 MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
21 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
22 BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
23 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
24 TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
26 ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
27 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 POSSIBILITY OF SUCH DAMAGE.
30*/
31
32/*---------------------------------------------------------------*
33 * For more about GridSite: http://www.gridsite.org/ *
34 *---------------------------------------------------------------*/
35
36#ifndef HEADER_GRIDSITE_H
37#define HEADER_GRIDSITE_H
38
39#ifndef GRST_VERSION
40#define GRST_VERSION 010500
41#endif
42
43#ifdef __cplusplus
44extern "C" {
45#endif
46
47#ifndef GRST_NO_OPENSSL
48
49#ifndef HEADER_SSL_H
50#include <openssl/ssl.h>
51#endif
52
53#ifndef HEADER_CRYPTO_H
54#include <openssl/crypto.h>
55#endif
56
57#endif
58
59#ifndef _TIME_H
60#include <time.h>
61#endif
62
63#ifndef _STDIO_H
64#include <stdio.h>
65#endif
66
67#ifndef _STDINT_H
68#include <stdint.h>
69#endif
70
71#ifndef FALSE
72#define FALSE (0)
73#endif
74#ifndef TRUE
75#define TRUE (!FALSE)
76#endif
77
78// Everything ok (= OpenSSL X509_V_OK)
79#define GRST_RET_OK 0
80
81// Failed for unspecified reason
82#define GRST_RET_FAILED 1000
83
84// Failed to find certificate in some cert store / directory
85#define GRST_RET_CERT_NOT_FOUND 1001
86
87// Bad signature
88#define GRST_RET_BAD_SIGNATURE 1002
89
90// No such file or directory
91#define GRST_RET_NO_SUCH_FILE 1003
92
93/* We use && now rather than if so this macro can be used inside if...else
94 but that means the function must return an int rather than be void */
95#define GRSTerrorLog(GRSTerrorLevel, ...) ((GRSTerrorLogFunc != NULL) && ((GRSTerrorLogFunc)(__FILE__, __LINE__, GRSTerrorLevel, __VA_ARGS__)))
96
97extern int (*GRSTerrorLogFunc)(char *, int, int, char *, ...);
98
99/* these levels are the same as Unix syslog() and Apache ap_log_error() */
100
101#define GRST_LOG_EMERG 0
102#define GRST_LOG_ALERT 1
103#define GRST_LOG_CRIT 2
104#define GRST_LOG_ERR 3
105#define GRST_LOG_WARNING 4
106#define GRST_LOG_NOTICE 5
107#define GRST_LOG_INFO 6
108#define GRST_LOG_DEBUG 7
109
110#define GRST_MAX_TIME_T INT32_MAX
111
112typedef struct { char *auri;
115 time_t notbefore;
116 time_t notafter;
118
119/* used by pre-AURI GRSTgaclCred structs */
120__attribute__ ((deprecated))
121typedef struct { char *name;
122 char *value;
123 void *next; } GRSTgaclNamevalue;
124
125typedef int GRSTgaclAction;
126typedef unsigned int GRSTgaclPerm;
127
128typedef struct { GRSTgaclCred *firstcred;
132
134
135typedef struct { GRSTgaclCred *firstcred; char *dnlists; } GRSTgaclUser;
136
137#define GRST_PERM_NONE 0
138#define GRST_PERM_READ 1
139#define GRST_PERM_EXEC 2
140#define GRST_PERM_LIST 4
141#define GRST_PERM_WRITE 8
142#define GRST_PERM_ADMIN 16
143#define GRST_PERM_ALL 31
144
145/* DO NOT USE PermIsNone!! */
146#define GRSTgaclPermIsNone(perm) ((perm) == 0)
147
148#define GRSTgaclPermHasNone(perm) ((perm) == 0)
149#define GRSTgaclPermHasRead(perm) (((perm) & GRST_PERM_READ ) != 0)
150#define GRSTgaclPermHasExec(perm) (((perm) & GRST_PERM_EXEC ) != 0)
151#define GRSTgaclPermHasList(perm) (((perm) & GRST_PERM_LIST ) != 0)
152#define GRSTgaclPermHasWrite(perm) (((perm) & GRST_PERM_WRITE) != 0)
153#define GRSTgaclPermHasAdmin(perm) (((perm) & GRST_PERM_ADMIN) != 0)
154
155#define GRST_ACTION_ALLOW 0
156#define GRST_ACTION_DENY 1
157
158#define GRST_HIST_PREFIX ".grsthist"
159#define GRST_ACL_FILE ".gacl"
160#define GRST_DN_LISTS "/etc/grid-security/dn-lists"
161#define GRST_RECURS_LIMIT 9
162
163#define GRST_PROXYCERTINFO_OLD_OID "1.3.6.1.4.1.3536.1.222"
164#define GRST_PROXYCERTINFO_OID "1.3.6.1.5.5.7.1.14"
165#define GRST_VOMS_OID "1.3.6.1.4.1.8005.100.100.5"
166#define GRST_VOMS_PK_CERT_LIST_OID "1.3.6.1.4.1.8005.100.100.10"
167#define GRST_VOMS_DIR "/etc/grid-security/vomsdir"
168#define GRST_KEYUSAGE_OID "2.5.29.15"
169
170#define GRST_ASN1_MAXCOORDLEN 50
171#define GRST_ASN1_MAXTAGS 500
172
173struct GRSTasn1TagList { char treecoords[GRST_ASN1_MAXCOORDLEN+1];
174 int start;
177 int tag; } ;
178
179#define GRST_X509_SERIAL_DIGITS 49
180
181typedef struct { int type; /* CA, user, proxy, VOMS, ... */
182 int errors; /* unchecked, bad sig, bad time */
183 char *issuer; /* Cert CA DN, EEC of PC, or VOMS DN */
184 char *dn; /* Cert DN, or VOMS AC holder DN */
185 char *value; /* VOMS FQAN or NULL */
186 time_t notbefore;
187 time_t notafter;
188 int delegation; /* relative to END of any chain */
189 char serial[GRST_X509_SERIAL_DIGITS+1];
190 char *ocsp; /* accessLocation field */
191 void *raw; /* X509 or VOMS Extension object */
193
194#define GRST_CERT_BAD_FORMAT 1
195#define GRST_CERT_BAD_CHAIN 2
196#define GRST_CERT_BAD_SIG 4
197#define GRST_CERT_BAD_TIME 8
198#define GRST_CERT_BAD_OCSP 16
199
200#define GRST_CERT_TYPE_CA 1
201#define GRST_CERT_TYPE_EEC 2
202#define GRST_CERT_TYPE_PROXY 3
203#define GRST_CERT_TYPE_VOMS 4
204#define GRST_CERT_TYPE_ROBOT 5
205
206/* a chain of certs, starting from the first CA */
208
209#ifndef GRST_NO_OPENSSL
212 STACK_OF(X509) *certstack, X509 *lastcert,
213 char *capath, char *vomsdir);
214int GRSTx509ChainLoadCheck(GRSTx509Chain **, STACK_OF(X509) *, X509 *, char *, char *);
215#endif
217
218#define GRST_HTTP_PORT 777
219#define GRST_HTTPS_PORT 488
220#define GRST_HTCP_PORT 777
221#define GRST_GSIFTP_PORT 2811
222
223#define GRSThtcpNOPop 0
224#define GRSThtcpTSTop 1
225
226typedef struct { unsigned char length_msb;
227 unsigned char length_lsb;
228 char text[1]; } GRSThtcpCountstr;
229
230#define GRSThtcpCountstrLen(string) (256*((string)->length_msb) + (string)->length_lsb)
231
232typedef struct { unsigned char total_length_msb;
233 unsigned char total_length_lsb;
234 unsigned char version_msb;
235 unsigned char version_lsb;
236 unsigned char data_length_msb;
237 unsigned char data_length_lsb;
238 unsigned int response : 4;
239 unsigned int opcode : 4;
240 unsigned int rr : 1;
241 unsigned int f1 : 1;
242 unsigned int reserved : 6;
243 unsigned int trans_id; /* must be 4 bytes */
251
252int GRSTgaclInit(void);
253
254__attribute__ ((deprecated))
256
257GRSTgaclCred *GRSTgaclCredCreate(char *, char *);
258
259__attribute__ ((deprecated))
260int GRSTgaclCredAddValue(GRSTgaclCred *, char *, char *);
261
262#define GRSTgaclCredGetAuri(cred) ((cred)->auri)
263
264#define GRSTgaclCredSetNotBefore(cred, time) ((cred)->notbefore = (time))
265#define GRSTgaclCredGetNotBefore(cred) ((cred)->notbefore)
266
267#define GRSTgaclCredSetNotAfter(cred, time) ((cred)->notafter = (time))
268#define GRSTgaclCredGetNotAfter(cred) ((cred)->notafter)
269
270#define GRSTgaclCredSetDelegation(cred, level) ((cred)->delegation = (level))
271#define GRSTgaclCredGetDelegation(cred) ((cred)->delegation)
272
273#define GRSTgaclCredSetNistLoa(cred, level) ((cred)->nist_loa = (level))
274#define GRSTgaclCredGetNistLoa(cred) ((cred)->nist_loa)
275
276/* #define GACLfreeCred(x) GRSTgaclCredFree((x)) */
278
279/* #define GACLaddCred(x,y) GRSTgaclEntryAddCred((x),(y)) */
281
282/* #define GACLdelCred(x,y) GRSTgaclEntryDelCred((x),(y)) */
284
285/* #define GACLprintCred(x,y) GRSTgaclCredPrint((x),(y)) */
287
289
290/* #define GACLnewEntry(x) GRSTgaclEntryNew((x)) */
292
293/* #define GACLfreeEntry(x) GRSTgaclEntryFree((x)) */
295
296/* #define GACLaddEntry(x,y) GRSTgaclAclAddEntry((x),(y)) */
298
299/* #define GACLprintEntry(x,y) GRSTgaclEntryPrint((x),(y)) */
300int GRSTgaclEntryPrint(GRSTgaclEntry *, FILE *);
301
302
303/* #define GACLprintPerm(x,y) GRSTgaclPermPrint((x),(y)) */
305
306/* #define GACLallowPerm(x,y) GRSTgaclEntryAllowPerm((x),(y)) */
308
309/* #define GACLunallowPerm(x,y) GRSTgaclEntryUnallowPerm((x),(y)) */
311
312/* #define GACLdenyPerm(x,y) GRSTgaclEntryDenyPerm((x),(y)) */
314
315/* #define GACLundenyPerm(x,y) GRSTgaclEntryUndenyPerm((x),(y)) */
317
318/* #define GACLpermToChar(x) GRSTgaclPermToChar((x)) */
320
321/* #define GACLcharToPerm(x) GRSTgaclPermFromChar((x)) */
323
324/* #define GACLnewAcl(x) GRSTgaclAclNew((x)) */
326
327/* #define GACLfreeAcl(x) GRSTgaclAclFree((x)) */
329
330/* #define GACLprintAcl(x,y) GRSTgaclAclPrint((x),(y)) */
331int GRSTgaclAclPrint(GRSTgaclAcl *, FILE *);
332
333/* #define GACLsaveAcl(x,y) GRSTgaclAclSave((y),(x)) */
334int GRSTgaclAclSave(GRSTgaclAcl *, char *);
335
336/* #define GACLloadAcl(x) GRSTgaclFileLoadAcl((x)) */
338
339/* #define GACLfindAclForFile(x) GRSTgaclFileFindAclname((x)) */
340char *GRSTgaclFileFindAclname(char *);
341
342/* #define GACLloadAclForFile(x) GRSTgaclFileLoadAcl((x)) */
344
345/* #define GACLisAclFile(x) GRSTgaclFileIsAcl((x)) */
346int GRSTgaclFileIsAcl(char *);
347
348
349/* #define GACLnewUser(x) GRSTgaclUserNew((x)) */
351
352/* #define GACLfreeUser(x) GRSTgaclUserFree((x)) */
354
355/* #define GACLuserAddCred(x,y) GRSTgaclUserAddCred((x),(y)) */
357
358/* #define GACLuserHasCred(x,y) GRSTgaclUserHasCred((x),(y)) */
360
361__attribute__ ((deprecated))
363
365
366/* #define GACLuserFindCredType(x,y) GRSTgaclUserFindCredtype((x),(y)) */
368
369__attribute__ ((deprecated))
371
372int GRSTgaclUserHasAURI(GRSTgaclUser *, char *);
373
374/* #define GACLtestUserAcl(x,y) GRSTgaclAclTestUser((x),(y)) */
376
377/* #define GACLtestExclAcl(x,y) GRSTgaclAclTestexclUser((x),(y)) */
379
380char *GRSThttpUrlDecode(char *);
381
382/* #define GACLurlEncode(x) GRSThttpUrlEncode((x)) */
383char *GRSThttpUrlEncode(char *);
384
385/* #define GACLmildUrlEncode(x) GRSThttpMildUrlEncode((x)) */
386char *GRSThttpUrlMildencode(char *);
387
388int GRSTx509NameCmp(char *, char *);
389
390#ifndef GRST_NO_OPENSSL
391int GRSTx509KnownCriticalExts(X509 *);
392
393int GRSTx509IsCA(X509 *);
394int GRSTx509CheckChain(int *, X509_STORE_CTX *);
395int GRSTx509VerifyCallback(int, X509_STORE_CTX *);
396
397__attribute__ ((deprecated))
398int GRSTx509GetVomsCreds(int *, int, size_t, char *, X509 *, STACK_OF(X509) *, char *);
399
400__attribute__ ((deprecated))
402
403__attribute__ ((deprecated))
404int GRSTx509CompactCreds(int *, int, size_t, char *, STACK_OF(X509) *, char *, X509 *);
405#endif
406
407char *GRSTx509CachedProxyFind(char *, char *, char *);
408char *GRSTx509FindProxyFileName(void);
409int GRSTx509MakeProxyCert(char **, FILE *, char *, char *, char *, int);
410#ifndef GRST_NO_OPENSSL
411char *GRSTx509CachedProxyKeyFind(char *, char *, char *, STACK_OF(X509) *);
412#endif
413int GRSTx509ProxyDestroy(char *, char *, char *);
414int GRSTx509ProxyGetTimes(char *, char *, char *, time_t *, time_t *);
415/*use GRSTx509CreateProxyRequestKS instead*/
416int GRSTx509CreateProxyRequest(char **, char **, char *);
417int GRSTx509CreateProxyRequestKS(char **reqtxt, char **keytxt, char *ocspurl, int keysize);
418/*use GRSTx509MakeProxyRequestKS istead*/
419int GRSTx509MakeProxyRequest(char **, char *, char *, char *);
420int GRSTx509MakeProxyRequestKS(char **reqtxt, char *proxydir,
421 char *delegation_id, char *user_dn, int keysize);
422
423char *GRSTx509MakeDelegationID(void);
424
425#ifndef GRST_NO_OPENSSL
426int GRSTx509StringToChain(STACK_OF(X509) **, char *);
427char *GRSTx509MakeProxyFileName(char *, STACK_OF(X509) *);
428#endif
429
430int GRSTx509CacheProxy(char *, char *, char *, char *);
431int GRST_is_id_safe(const char *);
432
433#define GRST_HEADFILE "gridsitehead.txt"
434#define GRST_FOOTFILE "gridsitefoot.txt"
435#define GRST_ADMIN_FILE "gridsite-admin.cgi"
436
437typedef struct { char *text;
439
440typedef struct { size_t size;
443
445void GRSThttpPrintf(GRSThttpBody *, char *, ...);
446int GRSThttpCopy(GRSThttpBody *, char *);
448int GRSThttpPrintHeaderFooter(GRSThttpBody *, char *, char *);
449int GRSThttpPrintHeader(GRSThttpBody *, char *);
450int GRSThttpPrintFooter(GRSThttpBody *, char *);
451char *GRSThttpGetCGI(char *);
452
453time_t GRSTasn1TimeToTimeT(char *, size_t);
454int GRSTasn1SearchTaglist(struct GRSTasn1TagList taglist[], int, char *);
455#ifndef GRST_NO_OPENSSL
456int GRSTasn1ParseDump(BIO *, unsigned char *, long,
457 struct GRSTasn1TagList taglist[], int, int *);
458#endif
459int GRSTasn1GetX509Name(char *, int, char *, char *,
460 struct GRSTasn1TagList taglist[], int);
461
462int GRSThtcpNOPrequestMake(char **, int *, unsigned int);
463int GRSThtcpNOPresponseMake(char **, int *, unsigned int);
464int GRSThtcpTSTrequestMake(char **, int *, unsigned int, char *, char *, char *);
465int GRSThtcpTSTresponseMake(char **, int *, unsigned int, char *, char *, char *);
466int GRSThtcpMessageParse(GRSThtcpMessage *, char *, int);
467
468#ifndef GRST_PASSCODE_JS
469//#define __GRST_PASSCODE_JS__
470#define GRST_PASSCODE_JS "<script type=\"text/javascript\" language=\"Javascript\"><!--\nfunction changeValue(formName){ if( document.forms[formName].passcode.value==\"\" ) document.forms[formName].passcode.value=getCookie(\"GRIDHTTP_PASSCODE\"); return true; } \nfunction getCookie(c_name){ if (document.cookie.length>0) { c_start=document.cookie.indexOf(c_name + \"=\"); if (c_start!=-1) { c_start=c_start + c_name.length+1; c_end=document.cookie.indexOf(\";\",c_start); if (c_end==-1) c_end=document.cookie.length; return unescape(document.cookie.substring(c_start,c_end)); }} return \"\"; } \n -->\n</script>"
471#endif
472
473#ifdef __cplusplus
474} // extern "C"
475#endif
476
477#endif // HEADER_GRIDSITE_H
char * GRSTgaclPermToChar(GRSTgaclPerm)
Definition: grst_gacl.c:531
int GRSTx509IsCA(X509 *)
Check if certificate can be used as a CA to sign standard X509 certs.
Definition: grst_canl_x509.c:299
char * GRSThttpGetCGI(char *)
Definition: grst_http.c:237
int GRSTx509ProxyDestroy(char *, char *, char *)
Destroy stored GSI proxy files.
Definition: grst_canl_x509.c:2503
int GRSTx509KnownCriticalExts(X509 *)
Check critical extensions.
Definition: grst_canl_x509.c:262
char *int GRSTgaclUserLoadDNlists(GRSTgaclUser *, char *)
Definition: grst_gacl.c:1185
GRSTgaclAcl * GRSTgaclAclLoadFile(char *)
Definition: grst_gacl.c:758
int(* GRSTerrorLogFunc)(char *, int, int, char *,...)
Definition: grst_err.c:40
int GRSTgaclEntryFree(GRSTgaclEntry *)
Definition: grst_gacl.c:386
int GRSTx509CheckChain(int *, X509_STORE_CTX *)
Definition: grst_canl_x509.c:1355
int GRSTgaclEntryPrint(GRSTgaclEntry *, FILE *)
Definition: grst_gacl.c:449
int GRSTx509MakeProxyCert(char **, FILE *, char *, char *, char *, int)
Make a GSI Proxy chain from a request, certificate and private key.
Definition: grst_canl_x509.c:1768
int GRSTx509MakeProxyRequest(char **, char *, char *, char *)
Create a X.509 request for a GSI proxy and its private key.
Definition: grst_canl_x509.c:2352
int GRSTgaclEntryDelCred(GRSTgaclEntry *, GRSTgaclCred *)
Definition: grst_gacl.c:296
int GRSThtcpTSTrequestMake(char **, int *, unsigned int, char *, char *, char *)
Definition: grst_htcp.c:116
int GRSTgaclFileIsAcl(char *)
Definition: grst_gacl.c:835
int GRSTasn1SearchTaglist(struct GRSTasn1TagList taglist[], int, char *)
Definition: grst_asn1.c:119
GRSTgaclAcl * GRSTgaclAclLoadforFile(char *)
Definition: grst_gacl.c:906
int GRSThtcpNOPresponseMake(char **, int *, unsigned int)
Definition: grst_htcp.c:81
char * GRSTgaclFileFindAclname(char *)
Definition: grst_gacl.c:848
int GRSTgaclEntryAddCred(GRSTgaclEntry *, GRSTgaclCred *)
Definition: grst_gacl.c:267
int GRSTx509CacheProxy(char *, char *, char *, char *)
Store a GSI proxy chain in the proxy cache, along with the private key.
Definition: grst_canl_x509.c:2779
int GRSTgaclUserHasCred(GRSTgaclUser *, GRSTgaclCred *)
Definition: grst_gacl.c:982
int GRSTgaclEntryAllowPerm(GRSTgaclEntry *, GRSTgaclPerm)
Definition: grst_gacl.c:503
int GRSTgaclUserAddCred(GRSTgaclUser *, GRSTgaclCred *)
Definition: grst_gacl.c:959
int GRSTx509NameCmp(char *, char *)
Compare X509 Distinguished Name strings.
Definition: grst_canl_x509.c:223
int
Definition: gridsite.h:398
GRSTgaclAcl * GRSTgaclAclNew(void)
Definition: grst_gacl.c:563
GRSTgaclNamevalue
Definition: gridsite.h:123
int GRSTgaclEntryUndenyPerm(GRSTgaclEntry *, GRSTgaclPerm)
Definition: grst_gacl.c:524
int GRSTgaclCredCredPrint(GRSTgaclCred *, FILE *)
char * GRSTx509FindProxyFileName(void)
Find proxy file name of the current user.
Definition: grst_canl_x509.c:1740
int GRSTx509CreateProxyRequest(char **, char **, char *)
Create a X.509 request for a GSI proxy and its private key.
Definition: grst_canl_x509.c:2236
char * GRSThttpUrlDecode(char *)
Definition: grst_http.c:330
int GRSThtcpMessageParse(GRSThtcpMessage *, char *, int)
Definition: grst_htcp.c:233
GRSTgaclPerm GRSTgaclAclTestexclUser(GRSTgaclAcl *, GRSTgaclUser *)
Definition: grst_gacl.c:1343
int GRSTasn1ParseDump(BIO *, unsigned char *, long, struct GRSTasn1TagList taglist[], int, int *)
Definition: grst_asn1.c:457
int GRSTx509ChainFree(GRSTx509Chain *)
Definition: grst_canl_x509.c:314
char * GRSThttpUrlEncode(char *)
Definition: grst_http.c:369
int GRSTgaclAclAddEntry(GRSTgaclAcl *, GRSTgaclEntry *)
Definition: grst_gacl.c:433
int GRSTx509ProxyGetTimes(char *, char *, char *, time_t *, time_t *)
Get start and finish validity times of stored GSI proxy file.
Definition: grst_canl_x509.c:2551
int GRSTx509VerifyCallback(int, X509_STORE_CTX *)
Example VerifyCallback routine.
Definition: grst_canl_x509.c:1381
int GRSTgaclUserFree(GRSTgaclUser *)
Definition: grst_gacl.c:946
int GRSTx509CreateProxyRequestKS(char **reqtxt, char **keytxt, char *ocspurl, int keysize)
Definition: grst_canl_x509.c:2225
GRSTgaclEntry * GRSTgaclEntryNew(void)
Definition: grst_gacl.c:367
int GRSThtcpNOPrequestMake(char **, int *, unsigned int)
Definition: grst_htcp.c:47
int GRSTasn1GetX509Name(char *, int, char *, char *, struct GRSTasn1TagList taglist[], int)
Definition: grst_asn1.c:497
GRSTgaclUser * GRSTgaclUserNew(GRSTgaclCred *)
Definition: grst_gacl.c:929
int GRSThtcpTSTresponseMake(char **, int *, unsigned int, char *, char *, char *)
Definition: grst_htcp.c:165
int GRSTgaclEntryDenyPerm(GRSTgaclEntry *, GRSTgaclPerm)
Definition: grst_gacl.c:517
time_t GRSTasn1TimeToTimeT(char *, size_t)
ASN1 time string (in a char *) to time_t.
Definition: grst_asn1.c:24
int GRSTx509MakeProxyRequestKS(char **reqtxt, char *proxydir, char *delegation_id, char *user_dn, int keysize)
Definition: grst_canl_x509.c:2338
char char X509 *char * GRSTx509CachedProxyFind(char *, char *, char *)
Find a proxy file in the proxy cache.
Definition: grst_canl_x509.c:2056
int GRST_is_id_safe(const char *)
Definition: grst_canl_x509.c:2876
void GRSThttpWriteOut(GRSThttpBody *)
Definition: grst_http.c:150
int GRSTx509StringToChain(STACK_OF(X509) **, char *)
Create a stack of X509 certificate from a PEM-encoded string.
Definition: grst_canl_x509.c:2593
int GRSTgaclAclPrint(GRSTgaclAcl *, FILE *)
Definition: grst_gacl.c:591
GRSTgaclCred * GRSTgaclUserFindCredtype(GRSTgaclUser *, char *)
Definition: grst_gacl.c:1046
void GRSThttpPrintf(GRSThttpBody *, char *,...)
Definition: grst_http.c:58
char * GRSTx509MakeProxyFileName(char *, STACK_OF(X509) *)
Return the short file name for the given delegation_id and user_dn.
Definition: grst_canl_x509.c:2692
int GRSTgaclInit(void)
Definition: grst_gacl.c:77
char * GRSTx509MakeDelegationID(void)
Returns a Delegation ID based on hash of GRST_CRED_0, ...
Definition: grst_canl_x509.c:2643
char * GRSThttpUrlMildencode(char *)
Definition: grst_http.c:402
int GRSThttpPrintHeaderFooter(GRSThttpBody *, char *, char *)
Definition: grst_http.c:168
GRSTgaclCred * GRSTgaclCredCreate(char *, char *)
Definition: grst_gacl.c:97
int GRSTgaclCredFree(GRSTgaclCred *)
Definition: grst_gacl.c:223
unsigned int GRSTgaclPerm
Definition: gridsite.h:126
int GRSTgaclPermPrint(GRSTgaclPerm, FILE *)
Definition: grst_gacl.c:489
int GRSTgaclCredCmpAuri(GRSTgaclCred *, GRSTgaclCred *)
Definition: grst_gacl.c:342
int GRSTx509ChainLoad(GRSTx509Chain **chain, STACK_OF(X509) *certstack, X509 *lastcert, char *capath, char *vomsdir)
Definition: grst_canl_x509.c:1015
__attribute__((deprecated)) typedef struct
Definition: gridsite.h:120
void GRSThttpBodyInit(GRSThttpBody *)
Definition: grst_http.c:53
int GRSThttpPrintFooter(GRSThttpBody *, char *)
Definition: grst_http.c:221
int GRSTgaclAction
Definition: gridsite.h:125
int GRSTx509ChainLoadCheck(GRSTx509Chain **, STACK_OF(X509) *, X509 *, char *, char *)
Check certificate chain for GSI proxy acceptability.
Definition: grst_canl_x509.c:1323
GRSTgaclUser *int GRSTgaclUserHasAURI(GRSTgaclUser *, char *)
Definition: grst_gacl.c:1284
GRSTgaclPerm GRSTgaclAclTestUser(GRSTgaclAcl *, GRSTgaclUser *)
Definition: grst_gacl.c:1298
int GRSThttpPrintHeader(GRSThttpBody *, char *)
Definition: grst_http.c:205
GRSTgaclPerm GRSTgaclPermFromChar(char *)
Definition: grst_gacl.c:546
char * GRSTx509CachedProxyKeyFind(char *, char *, char *, STACK_OF(X509) *)
Find a temporary proxy private key file in the proxy cache.
Definition: grst_canl_x509.c:2091
int GRSTx509CertLoad(GRSTx509Cert *, X509 *)
char X509 STACK_OF(X509) *
int GRSThttpCopy(GRSThttpBody *, char *)
Definition: grst_http.c:95
int GRSTgaclAclSave(GRSTgaclAcl *, char *)
Definition: grst_gacl.c:605
int GRSTgaclAclFree(GRSTgaclAcl *)
Definition: grst_gacl.c:579
int GRSTgaclEntryUnallowPerm(GRSTgaclEntry *, GRSTgaclPerm)
Definition: grst_gacl.c:510
int GRSTx509GetVomsCreds(int *lastcred, int maxcreds, size_t credlen, char *creds, X509 *usercert, STACK_OF(X509) *certstack, char *vomsdir)
Get the VOMS attributes in the extensions to the given cert stack.
Definition: grst_canl_x509.c:1538
GRSTgaclCred * GRSTx509CompactToCred(char *grst_cred)
Turn a Compact Cred line into a GRSTgaclCred object.
Definition: grst_canl_x509.c:1596
int GRSTx509CompactCreds(int *lastcred, int maxcreds, size_t credlen, char *creds, STACK_OF(X509) *certstack, char *vomsdir, X509 *peercert)
Get the credentials in an X509 cert/GSI proxy, including any VOMS.
Definition: grst_canl_x509.c:1657
int GRSTgaclUserSetDNlists(GRSTgaclUser *user, char *dnlists)
Definition: grst_gacl.c:1076
int GRSTgaclDNlistHasUser(char *listurl, GRSTgaclUser *user)
Definition: grst_gacl.c:1279
int GRSTgaclCredAddValue(GRSTgaclCred *cred, char *name, char *rawvalue)
Definition: grst_gacl.c:160
GRSTgaclCred * GRSTgaclCredNew(char *type)
Definition: grst_gacl.c:137
Definition: gridsite.h:173
int headerlength
Definition: gridsite.h:175
int length
Definition: gridsite.h:176
char treecoords[GRST_ASN1_MAXCOORDLEN+1]
Definition: gridsite.h:173
int tag
Definition: gridsite.h:177
int start
Definition: gridsite.h:174
Definition: gridsite.h:133
GRSTgaclEntry * firstentry
Definition: gridsite.h:133
Definition: gridsite.h:112
void * next
Definition: gridsite.h:117
char * auri
Definition: gridsite.h:112
int delegation
Definition: gridsite.h:113
int nist_loa
Definition: gridsite.h:114
time_t notbefore
Definition: gridsite.h:115
time_t notafter
Definition: gridsite.h:116
Definition: gridsite.h:128
GRSTgaclCred * firstcred
Definition: gridsite.h:128
GRSTgaclPerm denied
Definition: gridsite.h:130
GRSTgaclPerm allowed
Definition: gridsite.h:129
void * next
Definition: gridsite.h:131
Definition: gridsite.h:135
char * dnlists
Definition: gridsite.h:135
Definition: gridsite.h:226
unsigned char length_lsb
Definition: gridsite.h:227
unsigned char length_msb
Definition: gridsite.h:226
Definition: gridsite.h:232
GRSThtcpCountstr * req_hdrs
Definition: gridsite.h:247
unsigned char version_lsb
Definition: gridsite.h:235
unsigned int opcode
Definition: gridsite.h:239
unsigned char total_length_lsb
Definition: gridsite.h:233
GRSThtcpCountstr * cache_hdrs
Definition: gridsite.h:250
unsigned char total_length_msb
Definition: gridsite.h:232
GRSThtcpCountstr * version
Definition: gridsite.h:246
unsigned char data_length_lsb
Definition: gridsite.h:237
unsigned int f1
Definition: gridsite.h:241
unsigned int trans_id
Definition: gridsite.h:243
unsigned int rr
Definition: gridsite.h:240
unsigned int response
Definition: gridsite.h:238
GRSThtcpCountstr * entity_hdrs
Definition: gridsite.h:249
GRSThtcpCountstr * resp_hdrs
Definition: gridsite.h:248
unsigned char data_length_msb
Definition: gridsite.h:236
GRSThtcpCountstr * method
Definition: gridsite.h:244
GRSThtcpCountstr * uri
Definition: gridsite.h:245
unsigned int reserved
Definition: gridsite.h:242
unsigned char version_msb
Definition: gridsite.h:234
Definition: gridsite.h:440
GRSThttpCharsList * last
Definition: gridsite.h:442
GRSThttpCharsList * first
Definition: gridsite.h:441
size_t size
Definition: gridsite.h:440
Definition: gridsite.h:437
char * text
Definition: gridsite.h:437
void * next
Definition: gridsite.h:438
Definition: gridsite.h:181
int type
Definition: gridsite.h:181
time_t notafter
Definition: gridsite.h:187
int errors
Definition: gridsite.h:182
char * value
Definition: gridsite.h:185
char * dn
Definition: gridsite.h:184
char * ocsp
Definition: gridsite.h:190
int delegation
Definition: gridsite.h:188
time_t notbefore
Definition: gridsite.h:186
void * next
Definition: gridsite.h:192
char * issuer
Definition: gridsite.h:183
void * raw
Definition: gridsite.h:191
Definition: gridsite.h:207
GRSTx509Cert * firstcert
Definition: gridsite.h:207