globus_gsi_proxy_core  9.4
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
26 
30 #endif
31 
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
74 extern "C" {
75 #endif
76 
113 #define GLOBUS_GSI_PROXY_MODULE (&globus_i_gsi_proxy_module)
114 
115 extern
116 globus_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 
137 typedef struct globus_l_gsi_proxy_handle_s *
139 
153 typedef struct
154 globus_l_gsi_proxy_handle_attrs_s * globus_gsi_proxy_handle_attrs_t;
155 
156 
171 globus_result_t
173  globus_gsi_proxy_handle_t * handle,
174  globus_gsi_proxy_handle_attrs_t handle_attrs);
175 
176 globus_result_t
179 
180 globus_result_t
183  X509_REQ ** req);
184 
185 globus_result_t
188  X509_REQ * req);
189 
190 globus_result_t
193  EVP_PKEY ** proxy_key);
194 
195 globus_result_t
198  const EVP_PKEY * proxy_key);
199 
200 globus_result_t
203  globus_gsi_cert_utils_cert_type_t * type);
204 
205 globus_result_t
208  globus_gsi_cert_utils_cert_type_t type);
209 
210 
211 globus_result_t
214  int * time_valid);
215 
216 globus_result_t
219  int time_valid);
220 
221 globus_result_t
224  const unsigned char * policy_data,
225  int policy_length,
226  int policy_NID);
227 
228 globus_result_t
231  unsigned char ** policy_data,
232  int * policy_length,
233  int * policy_NID);
234 
235 globus_result_t
238  X509_EXTENSION * extension);
239 
240 globus_result_t
243  STACK_OF(X509_EXTENSION) * extensions);
244 
245 globus_result_t
248  STACK_OF(X509_EXTENSION) ** extension);
249 
250 globus_result_t
253  long pathlen);
254 
255 globus_result_t
258  int * pathlen);
259 
260 globus_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 
272 globus_result_t
273 globus_gsi_proxy_handle_get_proxy_cert_info_proxy_ssl(
275  PROXYCERTINFO ** pci);
276 
277 globus_result_t
278 globus_gsi_proxy_handle_set_proxy_cert_info_proxy_ssl(
280  PROXYCERTINFO * pci);
281 #else
282 globus_result_t
283 globus_gsi_proxy_handle_get_proxy_cert_info(
285  PROXY_CERT_INFO_EXTENSION ** pci);
286 
287 globus_result_t
288 globus_gsi_proxy_handle_set_proxy_cert_info(
290  PROXY_CERT_INFO_EXTENSION * pci);
291 #endif
292 
293 globus_result_t
296  char ** common_name);
297 
298 globus_result_t
301  const char * common_name);
302 
303 globus_result_t
306  globus_bool_t * is_limited);
307 
308 globus_result_t
311  globus_bool_t is_limited);
312 
313 globus_result_t
316  const EVP_MD ** algorithm);
317 
318 globus_result_t
321  int * key_bits);
322 
323 globus_result_t
326  int * init_prime);
327 
328 globus_result_t
331  int * skew);
332 
333 globus_result_t
336  void (**callback)(int, int, void *));
337 
351 globus_result_t
353  globus_gsi_proxy_handle_attrs_t * handle_attrs);
354 
355 globus_result_t
357  globus_gsi_proxy_handle_attrs_t handle_attrs);
358 
359 globus_result_t
363 
375 globus_result_t
378  BIO * output_bio);
379 
380 globus_result_t
383  BIO * input_bio);
384 
385 globus_result_t
388  globus_gsi_cred_handle_t issuer_credential,
389  BIO * output_bio);
390 
391 globus_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 
398 globus_result_t
401  globus_gsi_cred_handle_t * proxy_credential,
402  BIO * input_bio);
403 
404 globus_result_t
407  globus_gsi_cred_handle_t issuer,
408  globus_gsi_cred_handle_t * proxy_credential);
409 
410 globus_result_t
412  globus_gsi_proxy_handle_attrs_t handle_attrs,
413  int bits);
414 
415 globus_result_t
417  globus_gsi_proxy_handle_attrs_t handle_attrs,
418  int * bits);
419 
420 globus_result_t
422  globus_gsi_proxy_handle_attrs_t handle_attrs,
423  int prime);
424 
425 globus_result_t
427  globus_gsi_proxy_handle_attrs_t handle_attrs,
428  int * prime);
429 
430 globus_result_t
432  globus_gsi_proxy_handle_attrs_t handle_attrs,
433  const EVP_MD * algorithm);
434 
435 globus_result_t
437  globus_gsi_proxy_handle_attrs_t handle_attrs,
438  const EVP_MD ** algorithm);
439 
440 globus_result_t
443  int skew);
444 
445 globus_result_t
448  int * skew);
449 
450 globus_result_t
453  void (**callback)(int, int, void *));
454 
455 globus_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_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_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_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_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_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_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:1059
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_attrs_get_keybits(globus_gsi_proxy_handle_attrs_t handle_attrs, int *bits)
Get Key Bits.
Definition: globus_gsi_proxy_handle_attrs.c:191
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:213
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_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_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_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_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_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_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
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:1868
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
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_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_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:871
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_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_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_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_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_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_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_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_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
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_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_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_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_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_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_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_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_inquire_req(globus_gsi_proxy_handle_t handle, BIO *input_bio)
Inquire a proxy credential request.
Definition: globus_gsi_proxy.c:665
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:2116
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_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_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_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_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_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_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_get_signing_algorithm(globus_gsi_proxy_handle_t handle, const EVP_MD **algorithm)
Get Signing Algorithm.
Definition: globus_gsi_proxy_handle.c:1690