OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2014 Google Inc. All rights reserved. | 2 * Copyright (C) 2014 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
56 BLINK_PLATFORM_EXPORT WebCryptoKeyAlgorithm(WebCryptoAlgorithmId, PassOwnPtr <WebCryptoKeyAlgorithmParams>); | 56 BLINK_PLATFORM_EXPORT WebCryptoKeyAlgorithm(WebCryptoAlgorithmId, PassOwnPtr <WebCryptoKeyAlgorithmParams>); |
57 #endif | 57 #endif |
58 | 58 |
59 // FIXME: Delete this in favor of the create*() functions. | 59 // FIXME: Delete this in favor of the create*() functions. |
60 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm adoptParamsAndCreate(WebC ryptoAlgorithmId, WebCryptoKeyAlgorithmParams*); | 60 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm adoptParamsAndCreate(WebC ryptoAlgorithmId, WebCryptoKeyAlgorithmParams*); |
61 | 61 |
62 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createAes(WebCryptoAlgori thmId, unsigned short keyLengthBits); | 62 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createAes(WebCryptoAlgori thmId, unsigned short keyLengthBits); |
63 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createHmac(WebCryptoAlgor ithmId hash, unsigned keyLengthBits); | 63 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createHmac(WebCryptoAlgor ithmId hash, unsigned keyLengthBits); |
64 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createRsaHashed(WebCrypto AlgorithmId, unsigned modulusLengthBits, const unsigned char* publicExponent, un signed publicExponentSize, WebCryptoAlgorithmId hash); | 64 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createRsaHashed(WebCrypto AlgorithmId, unsigned modulusLengthBits, const unsigned char* publicExponent, un signed publicExponentSize, WebCryptoAlgorithmId hash); |
65 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createEc(WebCryptoAlgorit hmId, WebCryptoNamedCurve); | 65 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createEc(WebCryptoAlgorit hmId, WebCryptoNamedCurve); |
66 BLINK_PLATFORM_EXPORT static WebCryptoKeyAlgorithm createKdf(WebCryptoAlgori thmId); | |
66 | 67 |
67 ~WebCryptoKeyAlgorithm() { reset(); } | 68 ~WebCryptoKeyAlgorithm() { reset(); } |
68 | 69 |
69 WebCryptoKeyAlgorithm(const WebCryptoKeyAlgorithm& other) { assign(other); } | 70 WebCryptoKeyAlgorithm(const WebCryptoKeyAlgorithm& other) { assign(other); } |
70 WebCryptoKeyAlgorithm& operator=(const WebCryptoKeyAlgorithm& other) | 71 WebCryptoKeyAlgorithm& operator=(const WebCryptoKeyAlgorithm& other) |
71 { | 72 { |
72 assign(other); | 73 assign(other); |
73 return *this; | 74 return *this; |
74 } | 75 } |
75 | 76 |
76 BLINK_PLATFORM_EXPORT bool isNull() const; | 77 BLINK_PLATFORM_EXPORT bool isNull() const; |
77 | 78 |
78 BLINK_PLATFORM_EXPORT WebCryptoAlgorithmId id() const; | 79 BLINK_PLATFORM_EXPORT WebCryptoAlgorithmId id() const; |
79 | 80 |
80 BLINK_PLATFORM_EXPORT WebCryptoKeyAlgorithmParamsType paramsType() const; | 81 BLINK_PLATFORM_EXPORT WebCryptoKeyAlgorithmParamsType paramsType() const; |
81 | 82 |
82 // Returns the type-specific parameters for this key. If the requested | 83 // Returns the type-specific parameters for this key. If the requested |
83 // parameters are not applicable (for instance an HMAC key does not have | 84 // parameters are not applicable (for instance an HMAC key does not have |
84 // any AES parameters) then returns 0. | 85 // any AES parameters) then returns 0. |
85 BLINK_PLATFORM_EXPORT WebCryptoAesKeyAlgorithmParams* aesParams() const; | 86 BLINK_PLATFORM_EXPORT WebCryptoAesKeyAlgorithmParams* aesParams() const; |
86 BLINK_PLATFORM_EXPORT WebCryptoHmacKeyAlgorithmParams* hmacParams() const; | 87 BLINK_PLATFORM_EXPORT WebCryptoHmacKeyAlgorithmParams* hmacParams() const; |
87 BLINK_PLATFORM_EXPORT WebCryptoRsaHashedKeyAlgorithmParams* rsaHashedParams( ) const; | 88 BLINK_PLATFORM_EXPORT WebCryptoRsaHashedKeyAlgorithmParams* rsaHashedParams( ) const; |
88 BLINK_PLATFORM_EXPORT WebCryptoEcKeyAlgorithmParams* ecParams() const; | 89 BLINK_PLATFORM_EXPORT WebCryptoEcKeyAlgorithmParams* ecParams() const; |
90 BLINK_PLATFORM_EXPORT WebCryptoKdfKeyAlgorithmParams* kdfParams() const; | |
eroman
2015/01/07 00:40:31
Why is this necessary? It looks like your other ch
nharper
2015/01/08 00:58:39
It was added to make the switch statement in Seria
| |
89 | 91 |
90 // Write the algorithm parameters to a dictionary. | 92 // Write the algorithm parameters to a dictionary. |
91 BLINK_PLATFORM_EXPORT void writeToDictionary(WebCryptoKeyAlgorithmDictionary *) const; | 93 BLINK_PLATFORM_EXPORT void writeToDictionary(WebCryptoKeyAlgorithmDictionary *) const; |
92 | 94 |
93 private: | 95 private: |
94 BLINK_PLATFORM_EXPORT void assign(const WebCryptoKeyAlgorithm& other); | 96 BLINK_PLATFORM_EXPORT void assign(const WebCryptoKeyAlgorithm& other); |
95 BLINK_PLATFORM_EXPORT void reset(); | 97 BLINK_PLATFORM_EXPORT void reset(); |
96 | 98 |
97 WebPrivatePtr<WebCryptoKeyAlgorithmPrivate> m_private; | 99 WebPrivatePtr<WebCryptoKeyAlgorithmPrivate> m_private; |
98 }; | 100 }; |
99 | 101 |
100 } // namespace blink | 102 } // namespace blink |
101 | 103 |
102 #endif | 104 #endif |
OLD | NEW |