blob: c8ab9c400123daf1c79c8124a174f6e78cfd2364 (
plain)
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
|
// Copyright 2017 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/core/loader/subresource_integrity_helper.h"
#include "third_party/blink/renderer/core/execution_context/execution_context.h"
#include "third_party/blink/renderer/core/frame/use_counter.h"
#include "third_party/blink/renderer/core/inspector/console_types.h"
#include "third_party/blink/renderer/core/origin_trials/origin_trials.h"
#include "third_party/blink/renderer/platform/runtime_enabled_features.h"
namespace blink {
WebFeature GetWebFeature(
SubresourceIntegrity::ReportInfo::UseCounterFeature& feature) {
switch (feature) {
case SubresourceIntegrity::ReportInfo::UseCounterFeature::
kSRIElementWithMatchingIntegrityAttribute:
return WebFeature::kSRIElementWithMatchingIntegrityAttribute;
case SubresourceIntegrity::ReportInfo::UseCounterFeature::
kSRIElementWithNonMatchingIntegrityAttribute:
return WebFeature::kSRIElementWithNonMatchingIntegrityAttribute;
case SubresourceIntegrity::ReportInfo::UseCounterFeature::
kSRIElementIntegrityAttributeButIneligible:
return WebFeature::kSRIElementIntegrityAttributeButIneligible;
case SubresourceIntegrity::ReportInfo::UseCounterFeature::
kSRIElementWithUnparsableIntegrityAttribute:
return WebFeature::kSRIElementWithUnparsableIntegrityAttribute;
case SubresourceIntegrity::ReportInfo::UseCounterFeature::
kSRISignatureCheck:
return WebFeature::kSRISignatureCheck;
case SubresourceIntegrity::ReportInfo::UseCounterFeature::
kSRISignatureSuccess:
return WebFeature::kSRISignatureSuccess;
}
NOTREACHED();
return WebFeature::kSRIElementWithUnparsableIntegrityAttribute;
}
void SubresourceIntegrityHelper::DoReport(
ExecutionContext& execution_context,
const SubresourceIntegrity::ReportInfo& report_info) {
for (auto feature : report_info.UseCounts()) {
UseCounter::Count(&execution_context, GetWebFeature(feature));
}
HeapVector<Member<ConsoleMessage>> messages;
GetConsoleMessages(report_info, &messages);
for (const auto& message : messages) {
execution_context.AddConsoleMessage(message);
}
}
void SubresourceIntegrityHelper::GetConsoleMessages(
const SubresourceIntegrity::ReportInfo& report_info,
HeapVector<Member<ConsoleMessage>>* messages) {
DCHECK(messages);
for (const auto& message : report_info.ConsoleErrorMessages()) {
messages->push_back(ConsoleMessage::Create(kSecurityMessageSource,
kErrorMessageLevel, message));
}
}
SubresourceIntegrity::IntegrityFeatures SubresourceIntegrityHelper::GetFeatures(
ExecutionContext* execution_context) {
bool allow_signatures =
RuntimeEnabledFeatures::SignatureBasedIntegrityEnabledByRuntimeFlag() ||
OriginTrials::SignatureBasedIntegrityEnabled(execution_context);
return allow_signatures ? SubresourceIntegrity::IntegrityFeatures::kSignatures
: SubresourceIntegrity::IntegrityFeatures::kDefault;
}
} // namespace blink
|