globus_gsi_proxy_core 9.8
Loading...
Searching...
No Matches
globus_gsi_proxy.h
Go to the documentation of this file.
1/*
2 * Copyright 1999-2006 University of Chicago
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
22#ifndef GLOBUS_GLOBUS_GSI_PROXY_H
23#define GLOBUS_GLOBUS_GSI_PROXY_H
24
25#ifndef GLOBUS_GLOBAL_DOCUMENT_SET
30#endif
64#ifndef GLOBUS_DONT_DOCUMENT_INTERNAL
65#include "globus_gsi_credential.h"
66#include "globus_error_generic.h"
67#include "globus_error_openssl.h"
68#include "openssl/evp.h"
69#include "openssl/x509v3.h"
70#include "proxypolicy.h"
71#endif
72
73#ifdef __cplusplus
74extern "C" {
75#endif
76
113#define GLOBUS_GSI_PROXY_MODULE (&globus_i_gsi_proxy_module)
114
115extern
116globus_module_descriptor_t globus_i_gsi_proxy_module;
117
118#define _PCSL(s) globus_common_i18n_get_string(\
119 GLOBUS_GSI_PROXY_MODULE, \
120 s)
121
137typedef struct globus_l_gsi_proxy_handle_s *
139
153typedef struct
154globus_l_gsi_proxy_handle_attrs_s * globus_gsi_proxy_handle_attrs_t;
155
156
171globus_result_t
175
176globus_result_t
179
180globus_result_t
183 X509_REQ ** req);
184
185globus_result_t
188 X509_REQ * req);
189
190globus_result_t
193 EVP_PKEY ** proxy_key);
194
195globus_result_t
198 const EVP_PKEY * proxy_key);
199
200globus_result_t
203 globus_gsi_cert_utils_cert_type_t * type);
204
205globus_result_t
208 globus_gsi_cert_utils_cert_type_t type);
209
210
211globus_result_t
214 int * time_valid);
215
216globus_result_t
219 int time_valid);
220
221globus_result_t
224 const unsigned char * policy_data,
225 int policy_length,
226 int policy_NID);
227
228globus_result_t
231 unsigned char ** policy_data,
232 int * policy_length,
233 int * policy_NID);
234
235globus_result_t
238 X509_EXTENSION * extension);
239
240globus_result_t
243 STACK_OF(X509_EXTENSION) * extensions);
244
245globus_result_t
248 STACK_OF(X509_EXTENSION) ** extension);
249
250globus_result_t
253 long pathlen);
254
255globus_result_t
258 int * pathlen);
259
260globus_result_t
263
264#ifdef GLOBUS_GSI_PROXY_CORE_COMPAT_0
265#include "proxycertinfo.h"
266
267#define globus_gsi_proxy_handle_get_proxy_cert_info(h,p) \
268 globus_gsi_proxy_handle_get_proxy_cert_info_proxy_ssl(h,p)
269#define globus_gsi_proxy_handle_set_proxy_cert_info(h,p) \
270 globus_gsi_proxy_handle_set_proxy_cert_info_proxy_ssl(h,p)
271
272globus_result_t
273globus_gsi_proxy_handle_get_proxy_cert_info_proxy_ssl(
275 PROXYCERTINFO ** pci);
276
277globus_result_t
278globus_gsi_proxy_handle_set_proxy_cert_info_proxy_ssl(
280 PROXYCERTINFO * pci);
281#else
282globus_result_t
283globus_gsi_proxy_handle_get_proxy_cert_info(
285 PROXY_CERT_INFO_EXTENSION ** pci);
286
287globus_result_t
288globus_gsi_proxy_handle_set_proxy_cert_info(
290 PROXY_CERT_INFO_EXTENSION * pci);
291#endif
292
293globus_result_t
296 char ** common_name);
297
298globus_result_t
301 const char * common_name);
302
303globus_result_t
306 globus_bool_t * is_limited);
307
308globus_result_t
311 globus_bool_t is_limited);
312
313globus_result_t
316 const EVP_MD ** algorithm);
317
318globus_result_t
321 int * key_bits);
322
323globus_result_t
326 int * init_prime);
327
328globus_result_t
331 int * skew);
332
333globus_result_t
336 void (**callback)(int, int, void *));
337
351globus_result_t
353 globus_gsi_proxy_handle_attrs_t * handle_attrs);
354
355globus_result_t
358
359globus_result_t
363
375globus_result_t
378 BIO * output_bio);
379
380globus_result_t
383 BIO * input_bio);
384
385globus_result_t
388 globus_gsi_cred_handle_t issuer_credential,
389 BIO * output_bio);
390
391globus_result_t
394 globus_gsi_cred_handle_t issuer_credential,
395 globus_gsi_cred_handle_t peer_credential,
396 globus_gsi_cred_handle_t * resigned_credential);
397
398globus_result_t
401 globus_gsi_cred_handle_t * proxy_credential,
402 BIO * input_bio);
403
404globus_result_t
407 globus_gsi_cred_handle_t issuer,
408 globus_gsi_cred_handle_t * proxy_credential);
409
410globus_result_t
413 int bits);
414
415globus_result_t
418 int * bits);
419
420globus_result_t
423 int prime);
424
425globus_result_t
428 int * prime);
429
430globus_result_t
433 const EVP_MD * algorithm);
434
435globus_result_t
438 const EVP_MD ** algorithm);
439
440globus_result_t
443 int skew);
444
445globus_result_t
448 int * skew);
449
450globus_result_t
453 void (**callback)(int, int, void *));
454
455globus_result_t
458 void (*callback)(int, int, void *));
459
460#ifdef __cplusplus
461}
462#endif
463
464#endif /* GLOBUS_GLOBUS_GSI_PROXY_H */
globus_result_t globus_gsi_proxy_handle_set_common_name(globus_gsi_proxy_handle_t handle, const char *common_name)
Definition: globus_gsi_proxy_handle.c:2034
globus_result_t globus_gsi_proxy_handle_set_req(globus_gsi_proxy_handle_t handle, X509_REQ *req)
Set Request Set the certificate request in a GSI Proxy handle.
Definition: globus_gsi_proxy_handle.c:313
globus_result_t globus_gsi_proxy_handle_destroy(globus_gsi_proxy_handle_t handle)
Destroy a GSI Proxy handle.
Definition: globus_gsi_proxy_handle.c:205
globus_result_t globus_gsi_proxy_is_limited(globus_gsi_proxy_handle_t handle, globus_bool_t *is_limited)
Definition: globus_gsi_proxy_handle.c:2172
globus_result_t globus_gsi_proxy_handle_set_private_key(globus_gsi_proxy_handle_t handle, const EVP_PKEY *proxy_key)
Set the private key in a GSI Proxy handle.
Definition: globus_gsi_proxy_handle.c:491
globus_result_t globus_gsi_proxy_handle_attrs_get_key_gen_callback(globus_gsi_proxy_handle_attrs_t handle, void(**callback)(int, int, void *))
Get Key Gen Callback.
Definition: globus_gsi_proxy_handle_attrs.c:528
globus_result_t globus_gsi_proxy_handle_attrs_set_signing_algorithm(globus_gsi_proxy_handle_attrs_t handle_attrs, const EVP_MD *algorithm)
Set Signing Algorithm.
Definition: globus_gsi_proxy_handle_attrs.c:336
globus_result_t globus_gsi_proxy_handle_attrs_copy(globus_gsi_proxy_handle_attrs_t a, globus_gsi_proxy_handle_attrs_t *b)
Copy Attributes.
Definition: globus_gsi_proxy_handle_attrs.c:616
globus_result_t globus_gsi_proxy_handle_attrs_get_init_prime(globus_gsi_proxy_handle_attrs_t handle_attrs, int *prime)
Get Initial Prime Number.
Definition: globus_gsi_proxy_handle_attrs.c:283
globus_result_t globus_gsi_proxy_handle_attrs_set_keybits(globus_gsi_proxy_handle_attrs_t handle_attrs, int bits)
Set Key Bits.
Definition: globus_gsi_proxy_handle_attrs.c:151
globus_result_t globus_gsi_proxy_handle_attrs_get_clock_skew_allowable(globus_gsi_proxy_handle_attrs_t handle, int *skew)
Get Clock Skew Allowable.
Definition: globus_gsi_proxy_handle_attrs.c:478
globus_result_t globus_gsi_proxy_handle_attrs_set_clock_skew_allowable(globus_gsi_proxy_handle_attrs_t handle, int skew)
Set Clock Skew Allowable.
Definition: globus_gsi_proxy_handle_attrs.c:434
globus_result_t globus_gsi_proxy_handle_attrs_get_keybits(globus_gsi_proxy_handle_attrs_t handle_attrs, int *bits)
Get Key Bits.
Definition: globus_gsi_proxy_handle_attrs.c:191
struct globus_l_gsi_proxy_handle_attrs_s * globus_gsi_proxy_handle_attrs_t
Handle Attributes.
Definition: globus_gsi_proxy.h:153
globus_result_t globus_gsi_proxy_handle_attrs_init(globus_gsi_proxy_handle_attrs_t *handle_attrs)
Initialize Attributes.
Definition: globus_gsi_proxy_handle_attrs.c:65
globus_result_t globus_gsi_proxy_handle_attrs_set_init_prime(globus_gsi_proxy_handle_attrs_t handle_attrs, int prime)
Set Initial Prime Number.
Definition: globus_gsi_proxy_handle_attrs.c:241
globus_result_t globus_gsi_proxy_handle_attrs_destroy(globus_gsi_proxy_handle_attrs_t handle_attrs)
Destroy attributes.
Definition: globus_gsi_proxy_handle_attrs.c:123
globus_result_t globus_gsi_proxy_handle_attrs_get_signing_algorithm(globus_gsi_proxy_handle_attrs_t handle_attrs, const EVP_MD **algorithm)
Get Signing Algorithm.
Definition: globus_gsi_proxy_handle_attrs.c:383
globus_result_t globus_gsi_proxy_handle_attrs_set_key_gen_callback(globus_gsi_proxy_handle_attrs_t handle, void(*callback)(int, int, void *))
Set Key Gen Callback.
Definition: globus_gsi_proxy_handle_attrs.c:578
globus_result_t globus_gsi_proxy_handle_get_policy(globus_gsi_proxy_handle_t handle, unsigned char **policy_data, int *policy_length, int *policy_NID)
Get Policy.
Definition: globus_gsi_proxy_handle.c:771
globus_result_t globus_gsi_proxy_handle_get_req(globus_gsi_proxy_handle_t handle, X509_REQ **req)
Get the certificate request from a GSI Proxy handle.
Definition: globus_gsi_proxy_handle.c:254
globus_result_t globus_gsi_proxy_handle_init(globus_gsi_proxy_handle_t *handle, globus_gsi_proxy_handle_attrs_t handle_attrs)
Initialize a GSI Proxy handle.
Definition: globus_gsi_proxy_handle.c:86
globus_result_t globus_gsi_proxy_handle_get_keybits(globus_gsi_proxy_handle_t handle, int *key_bits)
Get Key Bits.
Definition: globus_gsi_proxy_handle.c:1746
globus_result_t globus_gsi_proxy_handle_get_extensions(globus_gsi_proxy_handle_t handle, STACK_OF(X509_EXTENSION) **extension)
Get X.509 Extensions.
Definition: globus_gsi_proxy_handle.c:1009
globus_result_t globus_gsi_proxy_handle_set_pathlen(globus_gsi_proxy_handle_t handle, long pathlen)
Set Path Length.
Definition: globus_gsi_proxy_handle.c:1081
globus_result_t globus_gsi_proxy_handle_get_clock_skew_allowable(globus_gsi_proxy_handle_t handle, int *skew)
Get Clock Skew <>
Definition: globus_gsi_proxy_handle.c:1857
globus_result_t globus_gsi_proxy_handle_set_time_valid(globus_gsi_proxy_handle_t handle, int time_valid)
Set Time Valid.
Definition: globus_gsi_proxy_handle.c:1248
globus_result_t globus_gsi_proxy_handle_get_pathlen(globus_gsi_proxy_handle_t handle, int *pathlen)
Get Path Length.
Definition: globus_gsi_proxy_handle.c:1142
globus_result_t globus_gsi_proxy_handle_get_init_prime(globus_gsi_proxy_handle_t handle, int *init_prime)
Get Init Prime.
Definition: globus_gsi_proxy_handle.c:1801
globus_result_t globus_gsi_proxy_handle_set_is_limited(globus_gsi_proxy_handle_t handle, globus_bool_t is_limited)
Set/Check Proxy Is Limited.
Definition: globus_gsi_proxy_handle.c:2092
struct globus_l_gsi_proxy_handle_s * globus_gsi_proxy_handle_t
GSI Proxy Handle.
Definition: globus_gsi_proxy.h:137
globus_result_t globus_gsi_proxy_handle_clear_cert_info(globus_gsi_proxy_handle_t handle)
Clear Cert Info.
Definition: globus_gsi_proxy_handle.c:1289
globus_result_t globus_gsi_proxy_handle_get_type(globus_gsi_proxy_handle_t handle, globus_gsi_cert_utils_cert_type_t *type)
Get Proxy Type.
Definition: globus_gsi_proxy_handle.c:553
globus_result_t globus_gsi_proxy_handle_set_policy(globus_gsi_proxy_handle_t handle, const unsigned char *policy_data, int policy_length, int policy_NID)
Set Policy.
Definition: globus_gsi_proxy_handle.c:679
globus_result_t globus_gsi_proxy_handle_set_type(globus_gsi_proxy_handle_t handle, globus_gsi_cert_utils_cert_type_t type)
Get Proxy Type.
Definition: globus_gsi_proxy_handle.c:605
globus_result_t globus_gsi_proxy_handle_add_extension(globus_gsi_proxy_handle_t handle, X509_EXTENSION *extension)
Add X.509 Extensions.
Definition: globus_gsi_proxy_handle.c:862
globus_result_t globus_gsi_proxy_handle_get_key_gen_callback(globus_gsi_proxy_handle_t handle, void(**callback)(int, int, void *))
Get Callback for Creating Keys.
Definition: globus_gsi_proxy_handle.c:1911
globus_result_t globus_gsi_proxy_handle_get_common_name(globus_gsi_proxy_handle_t handle, char **common_name)
Get/Set Proxy Common Name.
Definition: globus_gsi_proxy_handle.c:1971
globus_result_t globus_gsi_proxy_handle_get_private_key(globus_gsi_proxy_handle_t handle, EVP_PKEY **proxy_key)
Get the private key from a GSI Proxy handle.
Definition: globus_gsi_proxy_handle.c:375
globus_result_t globus_gsi_proxy_handle_set_extensions(globus_gsi_proxy_handle_t handle, STACK_OF(X509_EXTENSION) *extensions)
Set X.509 Extensions.
Definition: globus_gsi_proxy_handle.c:933
globus_result_t globus_gsi_proxy_handle_get_signing_algorithm(globus_gsi_proxy_handle_t handle, const EVP_MD **algorithm)
Get Signing Algorithm.
Definition: globus_gsi_proxy_handle.c:1690
globus_result_t globus_gsi_proxy_handle_get_time_valid(globus_gsi_proxy_handle_t handle, int *time_valid)
Get Time Valid.
Definition: globus_gsi_proxy_handle.c:1198
globus_result_t globus_gsi_proxy_assemble_cred(globus_gsi_proxy_handle_t handle, globus_gsi_cred_handle_t *proxy_credential, BIO *input_bio)
Assemble a proxy credential.
Definition: globus_gsi_proxy.c:2123
globus_result_t globus_gsi_proxy_create_req(globus_gsi_proxy_handle_t handle, BIO *output_bio)
Create a proxy credential request.
Definition: globus_gsi_proxy.c:220
globus_result_t globus_gsi_proxy_inquire_req(globus_gsi_proxy_handle_t handle, BIO *input_bio)
Inquire a proxy credential request.
Definition: globus_gsi_proxy.c:672
globus_result_t globus_gsi_proxy_resign_cert(globus_gsi_proxy_handle_t handle, globus_gsi_cred_handle_t issuer_credential, globus_gsi_cred_handle_t peer_credential, globus_gsi_cred_handle_t *resigned_credential)
Resign an existing certificate into a proxy.
Definition: globus_gsi_proxy.c:878
globus_result_t globus_gsi_proxy_create_signed(globus_gsi_proxy_handle_t handle, globus_gsi_cred_handle_t issuer, globus_gsi_cred_handle_t *proxy_credential)
Create Signed Proxy Certificate.
Definition: globus_gsi_proxy.c:1875
globus_result_t globus_gsi_proxy_sign_req(globus_gsi_proxy_handle_t handle, globus_gsi_cred_handle_t issuer_credential, BIO *output_bio)
Sign a proxy certificate request.
Definition: globus_gsi_proxy.c:1066