| /* |
| * Copyright 2015-2017 Hans Leidekker for CodeWeavers |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2.1 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the Free Software |
| * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA |
| */ |
| |
| #include <stdarg.h> |
| #include <assert.h> |
| |
| #include "windef.h" |
| #include "winbase.h" |
| #include "webservices.h" |
| |
| #include "wine/debug.h" |
| #include "wine/list.h" |
| #include "webservices_private.h" |
| |
| WINE_DEFAULT_DEBUG_CHANNEL(webservices); |
| |
| const char *debugstr_xmlstr( const WS_XML_STRING *str ) |
| { |
| if (!str) return "(null)"; |
| return debugstr_an( (const char *)str->bytes, str->length ); |
| } |
| |
| static CRITICAL_SECTION dict_cs; |
| static CRITICAL_SECTION_DEBUG dict_cs_debug = |
| { |
| 0, 0, &dict_cs, |
| { &dict_cs_debug.ProcessLocksList, |
| &dict_cs_debug.ProcessLocksList}, |
| 0, 0, {(DWORD_PTR)(__FILE__ ": dict_cs") } |
| }; |
| static CRITICAL_SECTION dict_cs = { &dict_cs_debug, -1, 0, 0, 0, 0 }; |
| |
| struct dictionary dict_builtin = |
| { |
| {{0x82704485,0x222a,0x4f7c,{0xb9,0x7b,0xe9,0xa4,0x62,0xa9,0x66,0x2b}}} |
| }; |
| |
| static inline int cmp_string( const unsigned char *str, ULONG len, const unsigned char *str2, ULONG len2 ) |
| { |
| if (len < len2) return -1; |
| else if (len > len2) return 1; |
| while (len--) |
| { |
| if (*str == *str2) { str++; str2++; } |
| else return *str - *str2; |
| } |
| return 0; |
| } |
| |
| /* return -1 and string id if found, sort index if not found */ |
| int find_string( const struct dictionary *dict, const unsigned char *data, ULONG len, ULONG *id ) |
| { |
| int i, c, min = 0, max = dict->dict.stringCount - 1; |
| const WS_XML_STRING *strings = dict->dict.strings; |
| while (min <= max) |
| { |
| i = (min + max) / 2; |
| c = cmp_string( data, len, strings[dict->sorted[i]].bytes, strings[dict->sorted[i]].length ); |
| if (c < 0) |
| max = i - 1; |
| else if (c > 0) |
| min = i + 1; |
| else |
| { |
| if (id) *id = strings[dict->sorted[i]].id; |
| return -1; |
| } |
| } |
| return max + 1; |
| } |
| |
| #define MIN_DICTIONARY_SIZE 256 |
| #define MAX_DICTIONARY_SIZE 2048 |
| |
| static HRESULT grow_dict( struct dictionary *dict, ULONG size ) |
| { |
| WS_XML_STRING *tmp; |
| ULONG new_size, *tmp_sorted; |
| |
| assert( !dict->dict.isConst ); |
| if (dict->size >= dict->dict.stringCount + size) return S_OK; |
| if (dict->size + size > MAX_DICTIONARY_SIZE) return WS_E_QUOTA_EXCEEDED; |
| |
| if (!dict->dict.strings) |
| { |
| new_size = max( MIN_DICTIONARY_SIZE, size ); |
| if (!(dict->dict.strings = heap_alloc( new_size * sizeof(*dict->dict.strings) ))) return E_OUTOFMEMORY; |
| if (!(dict->sorted = heap_alloc( new_size * sizeof(*dict->sorted) ))) |
| { |
| heap_free( dict->dict.strings ); |
| dict->dict.strings = NULL; |
| return E_OUTOFMEMORY; |
| } |
| dict->size = new_size; |
| return S_OK; |
| } |
| |
| new_size = max( dict->size * 2, size ); |
| if (!(tmp = heap_realloc( dict->dict.strings, new_size * sizeof(*tmp) ))) return E_OUTOFMEMORY; |
| dict->dict.strings = tmp; |
| if (!(tmp_sorted = heap_realloc( dict->sorted, new_size * sizeof(*tmp_sorted) ))) return E_OUTOFMEMORY; |
| dict->sorted = tmp_sorted; |
| |
| dict->size = new_size; |
| return S_OK; |
| } |
| |
| void clear_dict( struct dictionary *dict ) |
| { |
| ULONG i; |
| assert( !dict->dict.isConst ); |
| for (i = 0; i < dict->dict.stringCount; i++) heap_free( dict->dict.strings[i].bytes ); |
| heap_free( dict->dict.strings ); |
| dict->dict.strings = NULL; |
| dict->dict.stringCount = 0; |
| heap_free( dict->sorted ); |
| dict->sorted = NULL; |
| dict->size = 0; |
| } |
| |
| HRESULT insert_string( struct dictionary *dict, unsigned char *data, ULONG len, int i, ULONG *ret_id ) |
| { |
| ULONG id = dict->dict.stringCount; |
| HRESULT hr; |
| |
| assert( !dict->dict.isConst ); |
| if ((hr = grow_dict( dict, 1 )) != S_OK) return hr; |
| memmove( &dict->sorted[i] + 1, &dict->sorted[i], (dict->dict.stringCount - i) * sizeof(*dict->sorted) ); |
| dict->sorted[i] = id; |
| |
| dict->dict.strings[id].length = len; |
| dict->dict.strings[id].bytes = data; |
| dict->dict.strings[id].dictionary = &dict->dict; |
| dict->dict.strings[id].id = id; |
| dict->dict.stringCount++; |
| if (ret_id) *ret_id = id; |
| return S_OK; |
| } |
| |
| HRESULT CALLBACK insert_string_cb( void *state, const WS_XML_STRING *str, BOOL *found, ULONG *id, WS_ERROR *error ) |
| { |
| struct dictionary *dict = state; |
| int index = find_string( dict, str->bytes, str->length, id ); |
| HRESULT hr = S_OK; |
| |
| assert( !dict->dict.isConst ); |
| if (index == -1 || (hr = insert_string( dict, str->bytes, str->length, index, id )) == S_OK) *found = TRUE; |
| else *found = FALSE; |
| return hr; |
| } |
| |
| HRESULT add_xml_string( WS_XML_STRING *str ) |
| { |
| HRESULT hr = S_OK; |
| int index; |
| ULONG id; |
| |
| if (str->dictionary) return S_OK; |
| EnterCriticalSection( &dict_cs ); |
| if ((index = find_string( &dict_builtin, str->bytes, str->length, &id )) == -1) |
| { |
| heap_free( str->bytes ); |
| *str = dict_builtin.dict.strings[id]; |
| } |
| else if ((hr = insert_string( &dict_builtin, str->bytes, str->length, index, &id )) == S_OK) |
| { |
| *str = dict_builtin.dict.strings[id]; |
| } |
| LeaveCriticalSection( &dict_cs ); |
| return hr; |
| } |
| |
| WS_XML_STRING *alloc_xml_string( const unsigned char *data, ULONG len ) |
| { |
| WS_XML_STRING *ret; |
| |
| if (!(ret = heap_alloc_zero( sizeof(*ret) ))) return NULL; |
| if ((ret->length = len) && !(ret->bytes = heap_alloc( len ))) |
| { |
| heap_free( ret ); |
| return NULL; |
| } |
| if (data) |
| { |
| memcpy( ret->bytes, data, len ); |
| if (add_xml_string( ret ) != S_OK) WARN( "string not added to dictionary\n" ); |
| } |
| return ret; |
| } |
| |
| void free_xml_string( WS_XML_STRING *str ) |
| { |
| if (!str) return; |
| if (!str->dictionary) heap_free( str->bytes ); |
| heap_free( str ); |
| } |
| |
| WS_XML_STRING *dup_xml_string( const WS_XML_STRING *src, BOOL use_static_dict ) |
| { |
| WS_XML_STRING *ret; |
| unsigned char *data; |
| HRESULT hr; |
| int index; |
| ULONG id; |
| |
| if (!(ret = heap_alloc( sizeof(*ret) ))) return NULL; |
| if (src->dictionary) |
| { |
| *ret = *src; |
| return ret; |
| } |
| if (use_static_dict && (index = find_string( &dict_builtin_static, src->bytes, src->length, &id )) == -1) |
| { |
| *ret = dict_builtin_static.dict.strings[id]; |
| return ret; |
| } |
| EnterCriticalSection( &dict_cs ); |
| if ((index = find_string( &dict_builtin, src->bytes, src->length, &id )) == -1) |
| { |
| *ret = dict_builtin.dict.strings[id]; |
| LeaveCriticalSection( &dict_cs ); |
| return ret; |
| } |
| if (!(data = heap_alloc( src->length ))) |
| { |
| heap_free( ret ); |
| LeaveCriticalSection( &dict_cs ); |
| return NULL; |
| } |
| memcpy( data, src->bytes, src->length ); |
| if ((hr = insert_string( &dict_builtin, data, src->length, index, &id )) == S_OK) |
| { |
| *ret = dict_builtin.dict.strings[id]; |
| LeaveCriticalSection( &dict_cs ); |
| return ret; |
| } |
| LeaveCriticalSection( &dict_cs ); |
| |
| WARN( "string not added to dictionary\n" ); |
| ret->length = src->length; |
| ret->bytes = data; |
| ret->dictionary = NULL; |
| ret->id = 0; |
| return ret; |
| } |
| |
| const struct dictionary dict_builtin_static; |
| static const WS_XML_STRING dict_strings[] = |
| { |
| #define X(str, id) { sizeof(str) - 1, (BYTE *)(str), (WS_XML_DICTIONARY *)&dict_builtin_static.dict, id }, |
| X("mustUnderstand", 0) |
| X("Envelope", 1) |
| X("http://www.w3.org/2003/05/soap-envelope", 2) |
| X("http://www.w3.org/2005/08/addressing", 3) |
| X("Header", 4) |
| X("Action", 5) |
| X("To", 6) |
| X("Body", 7) |
| X("Algorithm", 8) |
| X("RelatesTo", 9) |
| X("http://www.w3.org/2005/08/addressing/anonymous", 10) |
| X("URI", 11) |
| X("Reference", 12) |
| X("MessageID", 13) |
| X("Id", 14) |
| X("Identifier", 15) |
| X("http://schemas.xmlsoap.org/ws/2005/02/rm", 16) |
| X("Transforms", 17) |
| X("Transform", 18) |
| X("DigestMethod", 19) |
| X("DigestValue", 20) |
| X("Address", 21) |
| X("ReplyTo", 22) |
| X("SequenceAcknowledgement", 23) |
| X("AcknowledgementRange", 24) |
| X("Upper", 25) |
| X("Lower", 26) |
| X("BufferRemaining", 27) |
| X("http://schemas.microsoft.com/ws/2006/05/rm", 28) |
| X("http://schemas.xmlsoap.org/ws/2005/02/rm/SequenceAcknowledgement", 29) |
| X("SecurityTokenReference", 30) |
| X("Sequence", 31) |
| X("MessageNumber", 32) |
| X("http://www.w3.org/2000/09/xmldsig#", 33) |
| X("http://www.w3.org/2000/09/xmldsig#enveloped-signature", 34) |
| X("KeyInfo", 35) |
| X("http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd", 36) |
| X("http://www.w3.org/2001/04/xmlenc#", 37) |
| X("http://schemas.xmlsoap.org/ws/2005/02/sc", 38) |
| X("DerivedKeyToken", 39) |
| X("Nonce", 40) |
| X("Signature", 41) |
| X("SignedInfo", 42) |
| X("CanonicalizationMethod", 43) |
| X("SignatureMethod", 44) |
| X("SignatureValue", 45) |
| X("DataReference", 46) |
| X("EncryptedData", 47) |
| X("EncryptionMethod", 48) |
| X("CipherData", 49) |
| X("CipherValue", 50) |
| X("http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd", 51) |
| X("Security", 52) |
| X("Timestamp", 53) |
| X("Created", 54) |
| X("Expires", 55) |
| X("Length", 56) |
| X("ReferenceList", 57) |
| X("ValueType", 58) |
| X("Type", 59) |
| X("EncryptedHeader", 60) |
| X("http://docs.oasis-open.org/wss/oasis-wss-wssecurity-secext-1.1.xsd", 61) |
| X("RequestSecurityTokenResponseCollection", 62) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust", 63) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust#BinarySecret", 64) |
| X("http://schemas.microsoft.com/ws/2006/02/transactions", 65) |
| X("s", 66) |
| X("Fault", 67) |
| X("MustUnderstand", 68) |
| X("role", 69) |
| X("relay", 70) |
| X("Code", 71) |
| X("Reason", 72) |
| X("Text", 73) |
| X("Node", 74) |
| X("Role", 75) |
| X("Detail", 76) |
| X("Value", 77) |
| X("Subcode", 78) |
| X("NotUnderstood", 79) |
| X("qname", 80) |
| X("", 81) |
| X("From", 82) |
| X("FaultTo", 83) |
| X("EndpointReference", 84) |
| X("PortType", 85) |
| X("ServiceName", 86) |
| X("PortName", 87) |
| X("ReferenceProperties", 88) |
| X("RelationshipType", 89) |
| X("Reply", 90) |
| X("a", 91) |
| X("http://schemas.xmlsoap.org/ws/2006/02/addressingidentity", 92) |
| X("Identity", 93) |
| X("Spn", 94) |
| X("Upn", 95) |
| X("Rsa", 96) |
| X("Dns", 97) |
| X("X509v3Certificate", 98) |
| X("http://www.w3.org/2005/08/addressing/fault", 99) |
| X("ReferenceParameters", 100) |
| X("IsReferenceParameter", 101) |
| X("http://www.w3.org/2005/08/addressing/reply", 102) |
| X("http://www.w3.org/2005/08/addressing/none", 103) |
| X("Metadata", 104) |
| X("http://schemas.xmlsoap.org/ws/2004/08/addressing", 105) |
| X("http://schemas.xmlsoap.org/ws/2004/08/addressing/role/anonymous", 106) |
| X("http://schemas.xmlsoap.org/ws/2004/08/addressing/fault", 107) |
| X("http://schemas.xmlsoap.org/ws/2004/06/addressingex", 108) |
| X("RedirectTo", 109) |
| X("Via", 110) |
| X("http://www.w3.org/2001/10/xml-exc-c14n#", 111) |
| X("PrefixList", 112) |
| X("InclusiveNamespaces", 113) |
| X("ec", 114) |
| X("SecurityContextToken", 115) |
| X("Generation", 116) |
| X("Label", 117) |
| X("Offset", 118) |
| X("Properties", 119) |
| X("Cookie", 120) |
| X("wsc", 121) |
| X("http://schemas.xmlsoap.org/ws/2004/04/sc", 122) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/sc/dk", 123) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/sc/sct", 124) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/RST/SCT", 125) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/RSTR/SCT", 126) |
| X("RenewNeeded", 127) |
| X("BadContextToken", 128) |
| X("c", 129) |
| X("http://schemas.xmlsoap.org/ws/2005/02/sc/dk", 130) |
| X("http://schemas.xmlsoap.org/ws/2005/02/sc/sct", 131) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RST/SCT", 132) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RSTR/SCT", 133) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RST/SCT/Renew", 134) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RSTR/SCT/Renew", 135) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RST/SCT/Cancel", 136) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RSTR/SCT/Cancel", 137) |
| X("http://www.w3.org/2001/04/xmlenc#aes128-cbc", 138) |
| X("http://www.w3.org/2001/04/xmlenc#kw-aes128", 139) |
| X("http://www.w3.org/2001/04/xmlenc#aes192-cbc", 140) |
| X("http://www.w3.org/2001/04/xmlenc#kw-aes192", 141) |
| X("http://www.w3.org/2001/04/xmlenc#aes256-cbc", 142) |
| X("http://www.w3.org/2001/04/xmlenc#kw-aes256", 143) |
| X("http://www.w3.org/2001/04/xmlenc#des-cbc", 144) |
| X("http://www.w3.org/2000/09/xmldsig#dsa-sha1", 145) |
| X("http://www.w3.org/2001/10/xml-exc-c14n#WithComments", 146) |
| X("http://www.w3.org/2000/09/xmldsig#hmac-sha1", 147) |
| X("http://www.w3.org/2001/04/xmldsig-more#hmac-sha256", 148) |
| X("http://schemas.xmlsoap.org/ws/2005/02/sc/dk/p_sha1", 149) |
| X("http://www.w3.org/2001/04/xmlenc#ripemd160", 150) |
| X("http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p", 151) |
| X("http://www.w3.org/2000/09/xmldsig#rsa-sha1", 152) |
| X("http://www.w3.org/2001/04/xmldsig-more#rsa-sha256", 153) |
| X("http://www.w3.org/2001/04/xmlenc#rsa-1_5", 154) |
| X("http://www.w3.org/2000/09/xmldsig#sha1", 155) |
| X("http://www.w3.org/2001/04/xmlenc#sha256", 156) |
| X("http://www.w3.org/2001/04/xmlenc#sha512", 157) |
| X("http://www.w3.org/2001/04/xmlenc#tripledes-cbc", 158) |
| X("http://www.w3.org/2001/04/xmlenc#kw-tripledes", 159) |
| X("http://schemas.xmlsoap.org/2005/02/trust/tlsnego#TLS_Wrap", 160) |
| X("http://schemas.xmlsoap.org/2005/02/trust/spnego#GSS_Wrap", 161) |
| X("http://schemas.microsoft.com/ws/2006/05/security", 162) |
| X("dnse", 163) |
| X("o", 164) |
| X("Password", 165) |
| X("PasswordText", 166) |
| X("Username", 167) |
| X("UsernameToken", 168) |
| X("BinarySecurityToken", 169) |
| X("EncodingType", 170) |
| X("KeyIdentifier", 171) |
| X("http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary", 172) |
| X("http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#HexBinary", 173) |
| X("http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Text", 174) |
| X("http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-x509-token-profile-1.0#X509SubjectKeyIdentifier", 175) |
| X("http://docs.oasis-open.org/wss/oasis-wss-kerberos-token-profile-1.1#GSS_Kerberosv5_AP_REQ", 176) |
| X("http://docs.oasis-open.org/wss/oasis-wss-kerberos-token-profile-1.1#GSS_Kerberosv5_AP_REQ1510", 177) |
| X("http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.0#SAMLAssertionID", 178) |
| X("Assertion", 179) |
| X("urn:oasis:names:tc:SAML:1.0:assertion", 180) |
| X("http://docs.oasis-open.org/wss/oasis-wss-rel-token-profile-1.0.pdf#license", 181) |
| X("FailedAuthentication", 182) |
| X("InvalidSecurityToken", 183) |
| X("InvalidSecurity", 184) |
| X("k", 185) |
| X("SignatureConfirmation", 186) |
| X("TokenType", 187) |
| X("http://docs.oasis-open.org/wss/oasis-wss-soap-message-security-1.1#ThumbprintSHA1", 188) |
| X("http://docs.oasis-open.org/wss/oasis-wss-soap-message-security-1.1#EncryptedKey", 189) |
| X("http://docs.oasis-open.org/wss/oasis-wss-soap-message-security-1.1#EncryptedKeySHA1", 190) |
| X("http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.1#SAMLV1.1", 191) |
| X("http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.1#SAMLV2.0", 192) |
| X("http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.1#SAMLID", 193) |
| X("AUTH-HASH", 194) |
| X("RequestSecurityTokenResponse", 195) |
| X("KeySize", 196) |
| X("RequestedTokenReference", 197) |
| X("AppliesTo", 198) |
| X("Authenticator", 199) |
| X("CombinedHash", 200) |
| X("BinaryExchange", 201) |
| X("Lifetime", 202) |
| X("RequestedSecurityToken", 203) |
| X("Entropy", 204) |
| X("RequestedProofToken", 205) |
| X("ComputedKey", 206) |
| X("RequestSecurityToken", 207) |
| X("RequestType", 208) |
| X("Context", 209) |
| X("BinarySecret", 210) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/spnego", 211) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/tlsnego", 212) |
| X("wst", 213) |
| X("http://schemas.xmlsoap.org/ws/2004/04/trust", 214) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/RST/Issue", 215) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/RSTR/Issue", 216) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/Issue", 217) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/CK/PSHA1", 218) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/SymmetricKey", 219) |
| X("http://schemas.xmlsoap.org/ws/2004/04/security/trust/Nonce", 220) |
| X("KeyType", 221) |
| X("http://schemas.xmlsoap.org/ws/2004/04/trust/SymmetricKey", 222) |
| X("http://schemas.xmlsoap.org/ws/2004/04/trust/PublicKey", 223) |
| X("Claims", 224) |
| X("InvalidRequest", 225) |
| X("RequestFailed", 226) |
| X("SignWith", 227) |
| X("EncryptWith", 228) |
| X("EncryptionAlgorithm", 229) |
| X("CanonicalizationAlgorithm", 230) |
| X("ComputedKeyAlgorithm", 231) |
| X("UseKey", 232) |
| X("http://schemas.microsoft.com/net/2004/07/secext/WS-SPNego", 233) |
| X("http://schemas.microsoft.com/net/2004/07/secext/TLSNego", 234) |
| X("t", 235) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RST/Issue", 236) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/RSTR/Issue", 237) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/Issue", 238) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/SymmetricKey", 239) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/CK/PSHA1", 240) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/Nonce", 241) |
| X("RenewTarget", 242) |
| X("CancelTarget", 243) |
| X("RequestedTokenCancelled", 244) |
| X("RequestedAttachedReference", 245) |
| X("RequestedUnattachedReference", 246) |
| X("IssuedTokens", 247) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/Renew", 248) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/Cancel", 249) |
| X("http://schemas.xmlsoap.org/ws/2005/02/trust/PublicKey", 250) |
| X("Access", 251) |
| X("AccessDecision", 252) |
| X("Advice", 253) |
| X("AssertionID", 254) |
| X("AssertionIDReference", 255) |
| X("Attribute", 256) |
| X("AttributeName", 257) |
| X("AttributeNamespace", 258) |
| X("AttributeStatement", 259) |
| X("AttributeValue", 260) |
| X("Audience", 261) |
| X("AudienceRestrictionCondition", 262) |
| X("AuthenticationInstant", 263) |
| X("AuthenticationMethod", 264) |
| X("AuthenticationStatement", 265) |
| X("AuthorityBinding", 266) |
| X("AuthorityKind", 267) |
| X("AuthorizationDecisionStatement", 268) |
| X("Binding", 269) |
| X("Condition", 270) |
| X("Conditions", 271) |
| X("Decision", 272) |
| X("DoNotCacheCondition", 273) |
| X("Evidence", 274) |
| X("IssueInstant", 275) |
| X("Issuer", 276) |
| X("Location", 277) |
| X("MajorVersion", 278) |
| X("MinorVersion", 279) |
| X("NameIdentifier", 280) |
| X("Format", 281) |
| X("NameQualifier", 282) |
| X("Namespace", 283) |
| X("NotBefore", 284) |
| X("NotOnOrAfter", 285) |
| X("saml", 286) |
| X("Statement", 287) |
| X("Subject", 288) |
| X("SubjectConfirmation", 289) |
| X("SubjectConfirmationData", 290) |
| X("ConfirmationMethod", 291) |
| X("urn:oasis:names:tc:SAML:1.0:cm:holder-of-key", 292) |
| X("urn:oasis:names:tc:SAML:1.0:cm:sender-vouches", 293) |
| X("SubjectLocality", 294) |
| X("DNSAddress", 295) |
| X("IPAddress", 296) |
| X("SubjectStatement", 297) |
| X("urn:oasis:names:tc:SAML:1.0:am:unspecified", 298) |
| X("xmlns", 299) |
| X("Resource", 300) |
| X("UserName", 301) |
| X("urn:oasis:names:tc:SAML:1.1:nameid-format:WindowsDomainQualifiedName", 302) |
| X("EmailName", 303) |
| X("urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress", 304) |
| X("u", 305) |
| X("ChannelInstance", 306) |
| X("http://schemas.microsoft.com/ws/2005/02/duplex", 307) |
| X("Encoding", 308) |
| X("MimeType", 309) |
| X("CarriedKeyName", 310) |
| X("Recipient", 311) |
| X("EncryptedKey", 312) |
| X("KeyReference", 313) |
| X("e", 314) |
| X("http://www.w3.org/2001/04/xmlenc#Element", 315) |
| X("http://www.w3.org/2001/04/xmlenc#Content", 316) |
| X("KeyName", 317) |
| X("MgmtData", 318) |
| X("KeyValue", 319) |
| X("RSAKeyValue", 320) |
| X("Modulus", 321) |
| X("Exponent", 322) |
| X("X509Data", 323) |
| X("X509IssuerSerial", 324) |
| X("X509IssuerName", 325) |
| X("X509SerialNumber", 326) |
| X("X509Certificate", 327) |
| X("AckRequested", 328) |
| X("http://schemas.xmlsoap.org/ws/2005/02/rm/AckRequested", 329) |
| X("AcksTo", 330) |
| X("Accept", 331) |
| X("CreateSequence", 332) |
| X("http://schemas.xmlsoap.org/ws/2005/02/rm/CreateSequence", 333) |
| X("CreateSequenceRefused", 334) |
| X("CreateSequenceResponse", 335) |
| X("http://schemas.xmlsoap.org/ws/2005/02/rm/CreateSequenceResponse", 336) |
| X("FaultCode", 337) |
| X("InvalidAcknowledgement", 338) |
| X("LastMessage", 339) |
| X("http://schemas.xmlsoap.org/ws/2005/02/rm/LastMessage", 340) |
| X("LastMessageNumberExceeded", 341) |
| X("MessageNumberRollover", 342) |
| X("Nack", 343) |
| X("netrm", 344) |
| X("Offer", 345) |
| X("r", 346) |
| X("SequenceFault", 347) |
| X("SequenceTerminated", 348) |
| X("TerminateSequence", 349) |
| X("http://schemas.xmlsoap.org/ws/2005/02/rm/TerminateSequence", 350) |
| X("UnknownSequence", 351) |
| X("http://schemas.microsoft.com/ws/2006/02/tx/oletx", 352) |
| X("oletx", 353) |
| X("OleTxTransaction", 354) |
| X("PropagationToken", 355) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wscoor", 356) |
| X("wscoor", 357) |
| X("CreateCoordinationContext", 358) |
| X("CreateCoordinationContextResponse", 359) |
| X("CoordinationContext", 360) |
| X("CurrentContext", 361) |
| X("CoordinationType", 362) |
| X("RegistrationService", 363) |
| X("Register", 364) |
| X("RegisterResponse", 365) |
| X("ProtocolIdentifier", 366) |
| X("CoordinatorProtocolService", 367) |
| X("ParticipantProtocolService", 368) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wscoor/CreateCoordinationContext", 369) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wscoor/CreateCoordinationContextResponse", 370) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wscoor/Register", 371) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wscoor/RegisterResponse", 372) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wscoor/fault", 373) |
| X("ActivationCoordinatorPortType", 374) |
| X("RegistrationCoordinatorPortType", 375) |
| X("InvalidState", 376) |
| X("InvalidProtocol", 377) |
| X("InvalidParameters", 378) |
| X("NoActivity", 379) |
| X("ContextRefused", 380) |
| X("AlreadyRegistered", 381) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat", 382) |
| X("wsat", 383) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Completion", 384) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Durable2PC", 385) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Volatile2PC", 386) |
| X("Prepare", 387) |
| X("Prepared", 388) |
| X("ReadOnly", 389) |
| X("Commit", 390) |
| X("Rollback", 391) |
| X("Committed", 392) |
| X("Aborted", 393) |
| X("Replay", 394) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Commit", 395) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Rollback", 396) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Committed", 397) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Aborted", 398) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Prepare", 399) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Prepared", 400) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/ReadOnly", 401) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/Replay", 402) |
| X("http://schemas.xmlsoap.org/ws/2004/10/wsat/fault", 403) |
| X("CompletionCoordinatorPortType", 404) |
| X("CompletionParticipantPortType", 405) |
| X("CoordinatorPortType", 406) |
| X("ParticipantPortType", 407) |
| X("InconsistentInternalState", 408) |
| X("mstx", 409) |
| X("Enlistment", 410) |
| X("protocol", 411) |
| X("LocalTransactionId", 412) |
| X("IsolationLevel", 413) |
| X("IsolationFlags", 414) |
| X("Description", 415) |
| X("Loopback", 416) |
| X("RegisterInfo", 417) |
| X("ContextId", 418) |
| X("TokenId", 419) |
| X("AccessDenied", 420) |
| X("InvalidPolicy", 421) |
| X("CoordinatorRegistrationFailed", 422) |
| X("TooManyEnlistments", 423) |
| X("Disabled", 424) |
| X("ActivityId", 425) |
| X("http://schemas.microsoft.com/2004/09/ServiceModel/Diagnostics", 426) |
| X("http://docs.oasis-open.org/wss/oasis-wss-kerberos-token-profile-1.1#Kerberosv5APREQSHA1", 427) |
| X("http://schemas.xmlsoap.org/ws/2002/12/policy", 428) |
| X("FloodMessage", 429) |
| X("LinkUtility", 430) |
| X("Hops", 431) |
| X("http://schemas.microsoft.com/net/2006/05/peer/HopCount", 432) |
| X("PeerVia", 433) |
| X("http://schemas.microsoft.com/net/2006/05/peer", 434) |
| X("PeerFlooder", 435) |
| X("PeerTo", 436) |
| X("http://schemas.microsoft.com/ws/2005/05/routing", 437) |
| X("PacketRoutable", 438) |
| X("http://schemas.microsoft.com/ws/2005/05/addressing/none", 439) |
| X("http://schemas.microsoft.com/ws/2005/05/envelope/none", 440) |
| X("http://www.w3.org/2001/XMLSchema-instance", 441) |
| X("http://www.w3.org/2001/XMLSchema", 442) |
| X("nil", 443) |
| X("type", 444) |
| X("char", 445) |
| X("boolean", 446) |
| X("byte", 447) |
| X("unsignedByte", 448) |
| X("short", 449) |
| X("unsignedShort", 450) |
| X("int", 451) |
| X("unsignedInt", 452) |
| X("long", 453) |
| X("unsignedLong", 454) |
| X("float", 455) |
| X("double", 456) |
| X("decimal", 457) |
| X("dateTime", 458) |
| X("string", 459) |
| X("base64Binary", 460) |
| X("anyType", 461) |
| X("duration", 462) |
| X("guid", 463) |
| X("anyURI", 464) |
| X("QName", 465) |
| X("time", 466) |
| X("date", 467) |
| X("hexBinary", 468) |
| X("gYearMonth", 469) |
| X("gYear", 470) |
| X("gMonthDay", 471) |
| X("gDay", 472) |
| X("gMonth", 473) |
| X("integer", 474) |
| X("positiveInteger", 475) |
| X("negativeInteger", 476) |
| X("nonPositiveInteger", 477) |
| X("nonNegativeInteger", 478) |
| X("normalizedString", 479) |
| X("ConnectionLimitReached", 480) |
| X("http://schemas.xmlsoap.org/soap/envelope/", 481) |
| X("actor", 482) |
| X("faultcode", 483) |
| X("faultstring", 484) |
| X("faultactor", 485) |
| X("detail", 486) |
| X("urn:oasis:names:tc:SAML:1.0:cm:bearer", 487) |
| #undef X |
| }; |
| |
| static const ULONG dict_sorted[] = |
| { |
| 81, 91, 129, 314, 185, 164, 346, 66, 235, 305, 14, 6, 114, 97, 96, 94, 11, 95, 110, 451, |
| 443, 121, 213, 7, 71, 82, 431, 343, 74, 75, 73, 59, 447, 445, 467, 163, 472, 463, 453, 409, |
| 69, 286, 466, 444, 383, 67, 117, 26, 40, 345, 465, 90, 25, 77, 482, 455, 470, 344, 353, 80, |
| 70, 449, 299, 331, 251, 330, 5, 253, 224, 390, 120, 76, 281, 4, 276, 56, 118, 436, 72, 394, |
| 232, 464, 486, 456, 473, 459, 357, 393, 21, 269, 209, 54, 204, 55, 83, 35, 317, 196, 221, 321, |
| 433, 387, 22, 78, 288, 419, 461, 446, 457, 474, 261, 272, 424, 308, 1, 274, 322, 93, 319, 202, |
| 277, 416, 104, 318, 309, 165, 87, 85, 388, 389, 364, 300, 391, 52, 31, 227, 301, 167, 323, 458, |
| 462, 411, 194, 8, 198, 179, 256, 392, 270, 418, 303, 337, 296, 13, 283, 284, 311, 12, 9, 41, |
| 287, 53, 187, 18, 58, 483, 471, 468, 425, 49, 271, 295, 410, 116, 15, 379, 112, 119, 109, 42, |
| 17, 485, 469, 254, 50, 206, 415, 20, 228, 339, 430, 435, 320, 127, 242, 208, 86, 484, 452, 420, |
| 328, 210, 243, 200, 19, 170, 312, 429, 376, 275, 247, 313, 278, 279, 285, 166, 417, 460, 448, 454, |
| 257, 199, 267, 46, 47, 421, 171, 32, 282, 79, 57, 226, 347, 168, 450, 252, 260, 201, 310, 380, |
| 332, 361, 225, 414, 413, 68, 280, 438, 45, 325, 0, 128, 27, 306, 39, 60, 377, 184, 44, 294, |
| 351, 327, 476, 475, 266, 362, 48, 354, 355, 365, 89, 297, 324, 326, 479, 381, 84, 378, 349, 98, |
| 258, 259, 291, 412, 366, 348, 423, 478, 477, 169, 360, 406, 273, 229, 113, 407, 100, 88, 363, 205, |
| 289, 24, 255, 264, 231, 182, 183, 101, 207, 115, 263, 334, 342, 186, 43, 480, 335, 338, 203, 30, |
| 265, 244, 197, 23, 290, 230, 358, 408, 341, 367, 368, 245, 262, 195, 246, 374, 404, 405, 422, 268, |
| 375, 442, 359, 37, 33, 3, 180, 487, 62, 155, 156, 157, 111, 2, 122, 16, 38, 316, 315, 144, |
| 154, 481, 441, 103, 28, 382, 145, 152, 139, 141, 143, 150, 99, 102, 298, 214, 130, 63, 147, 138, |
| 140, 142, 428, 356, 131, 292, 434, 159, 293, 307, 158, 10, 437, 151, 352, 162, 105, 403, 395, 402, |
| 238, 241, 248, 153, 108, 398, 399, 373, 149, 249, 211, 148, 400, 401, 396, 132, 212, 146, 65, 123, |
| 397, 340, 240, 133, 440, 124, 223, 384, 385, 371, 329, 250, 236, 34, 432, 107, 386, 237, 304, 234, |
| 439, 333, 161, 222, 64, 239, 92, 233, 160, 134, 217, 220, 350, 136, 135, 137, 125, 426, 218, 126, |
| 372, 215, 216, 106, 336, 29, 219, 61, 302, 193, 369, 191, 192, 181, 370, 178, 189, 36, 188, 51, |
| 190, 174, 427, 176, 173, 177, 172, 175, |
| }; |
| |
| const struct dictionary dict_builtin_static = |
| { |
| {{0xf93578f8,0x5852,0x4eb7,{0xa6,0xfc,0xe7,0x2b,0xb7,0x1d,0xb6,0x22}}, |
| (WS_XML_STRING *)dict_strings, sizeof(dict_strings)/sizeof(dict_strings[0]), TRUE}, |
| (ULONG *)dict_sorted |
| }; |
| |
| /************************************************************************** |
| * WsGetDictionary [webservices.@] |
| */ |
| HRESULT WINAPI WsGetDictionary( WS_ENCODING encoding, WS_XML_DICTIONARY **dict, WS_ERROR *error ) |
| { |
| TRACE( "%u %p %p\n", encoding, dict, error ); |
| if (error) FIXME( "ignoring error parameter\n" ); |
| |
| if (!dict) return E_INVALIDARG; |
| |
| if (encoding == WS_ENCODING_XML_BINARY_1 || encoding == WS_ENCODING_XML_BINARY_SESSION_1) |
| *dict = (WS_XML_DICTIONARY *)&dict_builtin_static; |
| else |
| *dict = NULL; |
| |
| return S_OK; |
| } |
| |
| /************************************************************************** |
| * WsXmlStringEquals [webservices.@] |
| */ |
| HRESULT WINAPI WsXmlStringEquals( const WS_XML_STRING *str1, const WS_XML_STRING *str2, WS_ERROR *error ) |
| { |
| TRACE( "%s %s %p\n", debugstr_xmlstr(str1), debugstr_xmlstr(str2), error ); |
| if (error) FIXME( "ignoring error parameter\n" ); |
| |
| if (!str1 || !str2) return E_INVALIDARG; |
| |
| if (str1->length != str2->length) return S_FALSE; |
| if (!memcmp( str1->bytes, str2->bytes, str1->length )) return S_OK; |
| return S_FALSE; |
| } |