Chromium Code Reviews| Index: Source/core/dom/RemoteSecurityContext.cpp |
| diff --git a/Source/core/dom/RemoteSecurityContext.cpp b/Source/core/dom/RemoteSecurityContext.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..49eb50b0c1a7bf797cecdbe69d211a643175bee4 |
| --- /dev/null |
| +++ b/Source/core/dom/RemoteSecurityContext.cpp |
| @@ -0,0 +1,52 @@ |
| +// 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 "config.h" |
| +#include "core/dom/RemoteSecurityContext.h" |
| + |
| +#include "core/frame/csp/ContentSecurityPolicy.h" |
| +#include "platform/weborigin/SecurityOrigin.h" |
| + |
| +namespace blink { |
| + |
| +RemoteSecurityContext::RemoteSecurityContext() |
| + : SecurityContext() |
| +{ |
| +} |
| + |
| +PassRefPtr<RemoteSecurityContext> RemoteSecurityContext::create() |
| +{ |
| + RefPtr<RemoteSecurityContext> securityContext = |
| + adoptRef(new RemoteSecurityContext()); |
| + |
| + // RemoteSecurityContext's origin is expected to stay uninitialized until |
| + // we set it using replicated origin data from the browser process. |
| + ASSERT(!securityContext->haveInitializedSecurityOrigin()); |
| + |
| + // CSP will not be replicated for RemoteSecurityContexts, as it is moving |
| + // to the browser process. For now, initialize CSP to a default |
| + // locked-down policy. |
| + RefPtr<ContentSecurityPolicy> csp = ContentSecurityPolicy::create(); |
| + securityContext->setContentSecurityPolicy(csp); |
|
dcheng
2014/11/12 21:57:40
Nit: I would just combine these two lines, since y
alexmos
2014/11/18 18:35:17
Done.
|
| + |
| + // TODO(alexmos): Document::initSecurityContext has a few other things we |
| + // may eventually want here, such as enforcing a setting to |
| + // grantUniversalAccess(). |
| + |
| + return securityContext.release(); |
| +} |
| + |
| +void RemoteSecurityContext::setReplicatedOrigin(PassRefPtr<SecurityOrigin> origin) |
| +{ |
| + // FIXME(alexmos): currently, replicated security origins are passed only |
| + // at RemoteFrame creation time. Eventually, this class will also need to |
| + // handle origin updates to handle cases like setting document.domain, but |
| + // for now, check that this is the first and only time we are setting the |
| + // origin. |
| + ASSERT(!haveInitializedSecurityOrigin()); |
| + setSecurityOrigin(origin); |
| +} |
| + |
| + |
| +} // namespace blink |