2 * Copyright (C) 2013 Google Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above
11 * copyright notice, this list of conditions and the following disclaimer
12 * in the documentation and/or other materials provided with the
14 * * Neither the name of Google Inc. nor the names of its
15 * contributors may be used to endorse or promote products derived from
16 * this software without specific prior written permission.
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 #include "public/platform/WebCryptoKey.h"
34 #include "public/platform/WebCryptoAlgorithm.h"
35 #include "public/platform/WebCryptoAlgorithmParams.h"
36 #include "public/platform/WebCryptoKeyAlgorithm.h"
37 #include "wtf/OwnPtr.h"
38 #include "wtf/ThreadSafeRefCounted.h"
42 class WebCryptoKeyPrivate
: public ThreadSafeRefCounted
<WebCryptoKeyPrivate
> {
44 WebCryptoKeyPrivate(PassOwnPtr
<WebCryptoKeyHandle
> handle
, WebCryptoKeyType type
, bool extractable
, const WebCryptoKeyAlgorithm
& algorithm
, WebCryptoKeyUsageMask usages
)
47 , extractable(extractable
)
48 , algorithm(algorithm
)
51 ASSERT(!algorithm
.isNull());
54 const OwnPtr
<WebCryptoKeyHandle
> handle
;
55 const WebCryptoKeyType type
;
56 const bool extractable
;
57 const WebCryptoKeyAlgorithm algorithm
;
58 const WebCryptoKeyUsageMask usages
;
61 WebCryptoKey
WebCryptoKey::create(WebCryptoKeyHandle
* handle
, WebCryptoKeyType type
, bool extractable
, const WebCryptoKeyAlgorithm
& algorithm
, WebCryptoKeyUsageMask usages
)
64 key
.m_private
= adoptRef(new WebCryptoKeyPrivate(adoptPtr(handle
), type
, extractable
, algorithm
, usages
));
68 WebCryptoKey
WebCryptoKey::createNull()
70 return WebCryptoKey();
73 WebCryptoKeyHandle
* WebCryptoKey::handle() const
76 return m_private
->handle
.get();
79 WebCryptoKeyType
WebCryptoKey::type() const
82 return m_private
->type
;
85 bool WebCryptoKey::extractable() const
88 return m_private
->extractable
;
91 const WebCryptoKeyAlgorithm
& WebCryptoKey::algorithm() const
94 return m_private
->algorithm
;
97 WebCryptoKeyUsageMask
WebCryptoKey::usages() const
100 return m_private
->usages
;
103 bool WebCryptoKey::isNull() const
105 return m_private
.isNull();
108 bool WebCryptoKey::keyUsageAllows(const blink::WebCryptoKeyUsage usage
) const
110 return ((m_private
->usages
& usage
) != 0);
113 void WebCryptoKey::assign(const WebCryptoKey
& other
)
115 m_private
= other
.m_private
;
118 void WebCryptoKey::reset()