1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
|
/*
* Copyright (C) 2022 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "config.h"
#include "AuthenticationExtensionsClientOutputs.h"
#if ENABLE(WEB_AUTHN)
#include "CBORReader.h"
#include "CBORWriter.h"
namespace WebCore {
std::optional<AuthenticationExtensionsClientOutputs> AuthenticationExtensionsClientOutputs::fromCBOR(const Vector<uint8_t>& buffer)
{
std::optional<cbor::CBORValue> decodedValue = cbor::CBORReader::read(buffer);
if (!decodedValue || !decodedValue->isMap())
return std::nullopt;
AuthenticationExtensionsClientOutputs clientOutputs;
const auto& decodedMap = decodedValue->getMap();
auto it = decodedMap.find(cbor::CBORValue("appid"));
if (it != decodedMap.end() && it->second.isBool())
clientOutputs.appid = it->second.getBool();
it = decodedMap.find(cbor::CBORValue("credProps"));
if (it != decodedMap.end() && it->second.isMap()) {
CredentialPropertiesOutput credProps;
it = it->second.getMap().find(cbor::CBORValue("rk"));
if (it != decodedMap.end() && it->second.isBool())
credProps.rk = it->second.getBool();
clientOutputs.credProps = credProps;
}
it = decodedMap.find(cbor::CBORValue("largeBlob"));
if (it != decodedMap.end() && it->second.isMap()) {
const auto& largeBlobMap = it->second.getMap();
LargeBlobOutputs largeBlob;
auto largeBlobIt = largeBlobMap.find(cbor::CBORValue("supported"));
if (largeBlobIt != largeBlobMap.end() && largeBlobIt->second.isBool())
largeBlob.supported = largeBlobIt->second.getBool();
largeBlobIt = largeBlobMap.find(cbor::CBORValue("blob"));
if (largeBlobIt != largeBlobMap.end() && largeBlobIt->second.isByteString()) {
RefPtr<ArrayBuffer> blob = ArrayBuffer::create(largeBlobIt->second.getByteString());
largeBlob.blob = WTFMove(blob);
}
largeBlobIt = largeBlobMap.find(cbor::CBORValue("written"));
if (largeBlobIt != largeBlobMap.end() && largeBlobIt->second.isBool())
largeBlob.written = largeBlobIt->second.getBool();
clientOutputs.largeBlob = largeBlob;
}
return clientOutputs;
}
Vector<uint8_t> AuthenticationExtensionsClientOutputs::toCBOR() const
{
cbor::CBORValue::MapValue clientOutputsMap;
if (appid)
clientOutputsMap[cbor::CBORValue("appid")] = cbor::CBORValue(*appid);
if (credProps) {
cbor::CBORValue::MapValue credPropsMap;
credPropsMap[cbor::CBORValue("rk")] = cbor::CBORValue(credProps->rk);
clientOutputsMap[cbor::CBORValue("credProps")] = cbor::CBORValue(credPropsMap);
}
if (largeBlob) {
cbor::CBORValue::MapValue largeBlobMap;
if (largeBlob->supported)
largeBlobMap[cbor::CBORValue("supported")] = cbor::CBORValue(largeBlob->supported.value());
if (largeBlob->blob)
largeBlobMap[cbor::CBORValue("blob")] = cbor::CBORValue(largeBlob->blob->toVector());
if (largeBlob->written)
largeBlobMap[cbor::CBORValue("written")] = cbor::CBORValue(largeBlob->written.value());
clientOutputsMap[cbor::CBORValue("largeBlob")] = cbor::CBORValue(largeBlobMap);
}
auto clientOutputs = cbor::CBORWriter::write(cbor::CBORValue(WTFMove(clientOutputsMap)));
ASSERT(clientOutputs);
return *clientOutputs;
}
} // namespace WebCore
#endif // ENABLE(WEB_AUTHN)
|