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
|
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "third_party/blink/renderer/modules/credentialmanager/federated_credential.h"
#include "third_party/blink/renderer/bindings/core/v8/exception_state.h"
#include "third_party/blink/renderer/modules/credentialmanager/federated_credential_init.h"
namespace blink {
namespace {
constexpr char kFederatedCredentialType[] = "federated";
}
FederatedCredential* FederatedCredential::Create(
const FederatedCredentialInit& data,
ExceptionState& exception_state) {
if (data.id().IsEmpty())
exception_state.ThrowTypeError("'id' must not be empty.");
if (data.provider().IsEmpty())
exception_state.ThrowTypeError("'provider' must not be empty.");
KURL icon_url = ParseStringAsURLOrThrow(data.iconURL(), exception_state);
KURL provider_url = ParseStringAsURLOrThrow(data.provider(), exception_state);
if (exception_state.HadException())
return nullptr;
return new FederatedCredential(
data.id(), SecurityOrigin::Create(provider_url), data.name(), icon_url);
}
FederatedCredential* FederatedCredential::Create(
const String& id,
scoped_refptr<const SecurityOrigin> provider,
const String& name,
const KURL& icon_url) {
return new FederatedCredential(id, provider, name, icon_url);
}
FederatedCredential::FederatedCredential(
const String& id,
scoped_refptr<const SecurityOrigin> provider,
const String& name,
const KURL& icon_url)
: Credential(id, kFederatedCredentialType),
provider_(provider),
name_(name),
icon_url_(icon_url) {
DCHECK(provider);
}
bool FederatedCredential::IsFederatedCredential() const {
return true;
}
} // namespace blink
|