00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 #include <axutil_utils_defines.h>
00018 #include <axis2_defines.h>
00019 #include <axutil_env.h>
00020 #include <axiom_soap.h>
00021 #include <axis2_msg_ctx.h>
00022 #include <oxs_asym_ctx.h>
00023 #include <oxs_xml_encryption.h>
00024 #include <rampart_context.h>
00025 #include <axutil_utils.h>
00026 #include <axiom.h>
00027 #include <rampart_saml_token.h>
00028 #include <oxs_key_mgr.h>
00029 #include <rp_rampart_config.h>
00030 
00037 #ifndef RAMPART_SAML_H
00038 #define RAMPART_SAML_H
00039 
00040 #ifdef __cplusplus
00041 extern "C" {
00042 #endif
00043 
00044 #define RAMPART_ST_FAULT_SECURITYTOKENUNAVAILABLE_STR   "A referenced SAML assertion could not be retrieved."
00045 #define RAMPART_ST_FAULT_UNSUPPORTEDSECURITYTOKEN_STR   "An assertion contains a <saml:condition> element that the receive does not understand."
00046 #define RAMPART_ST_FAULT_FAILEDCHECK_STR                "A signature withing an assertion or referencing an assertion is invalid."
00047 #define RAMPART_ST_FAULT_INVALIDSECURITYTOKEN_STR       "The issuer of an assertion is not acceptable to the receiver."                
00048 
00049 #define RAMPART_ST_FAULT_SECURITYTOKENUNAVAILABLE_CODE  "wsse:SecurityTokenUnavailable"
00050 #define RAMPART_ST_FAULT_UNSUPPORTEDSECURITYTOKEN_CODE  "wsse:UnsupportedSecurityToken"
00051 #define RAMPART_ST_FAULT_FAILEDCHECK_CODE               "wsse:FailedCheck"
00052 #define RAMPART_ST_FAULT_INVALIDSECURITYTOKEN_CODE      "wsse:InvalidSecurityToken"                
00053 
00054 #define RAMPART_SAML_FAULT_CODE                         "env:Sender"
00055 
00065 AXIS2_EXTERN axis2_status_t AXIS2_CALL
00066 rampart_saml_supporting_token_build(const axutil_env_t *env, 
00067                          rampart_context_t *rampart_context,                         
00068                          axiom_node_t *sec_node,
00069                          axutil_array_list_t *sign_parts);
00079 AXIS2_EXTERN axis2_status_t AXIS2_CALL
00080 rampart_saml_token_validate(const axutil_env_t *env, 
00081                             rampart_context_t *rampart_context, 
00082                             axiom_node_t *assertion);
00090 AXIS2_EXTERN char * AXIS2_CALL
00091 rampart_saml_token_get_subject_confirmation(const axutil_env_t *env, 
00092                                             axiom_node_t *assertion);
00093 
00094 
00102 AXIS2_EXTERN int AXIS2_CALL
00103 rampart_saml_token_fault_securitytokenunavailable(axutil_env_t *env, 
00104                                                   axis2_msg_ctx_t *ctx);
00112 AXIS2_EXTERN int AXIS2_CALL
00113 rampart_saml_token_fault_unsupportedsecuritytoken(axutil_env_t *env, 
00114                                                   axis2_msg_ctx_t *ctx);
00122 AXIS2_EXTERN int AXIS2_CALL
00123 rampart_saml_token_fault_failedcheck(axutil_env_t *env, 
00124                                                   axis2_msg_ctx_t *ctx);
00132 AXIS2_EXTERN int AXIS2_CALL
00133 rampart_saml_token_fault_invalidsecuritytoken(axutil_env_t *env, 
00134                                                   axis2_msg_ctx_t *ctx);
00135 
00136 
00137 AXIS2_EXTERN rampart_saml_token_t * AXIS2_CALL
00138 rampart_saml_add_token(rampart_context_t *rampart_context, 
00139                                            const axutil_env_t *env, axiom_node_t *assertion, 
00140                                            axiom_node_t *str,
00141                                            rampart_st_type_t type);
00142 #ifdef __cplusplus
00143 }
00144 #endif
00145 
00146 #endif