Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2007, 2010 Apple Inc. All rights reserved. | 2 * Copyright (C) 2007, 2010 Apple Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 66 result.append(')'); | 66 result.append(')'); |
| 67 } | 67 } |
| 68 return result.toString(); | 68 return result.toString(); |
| 69 } | 69 } |
| 70 | 70 |
| 71 bool CSSFontFaceSrcValue::hasFailedOrCanceledSubresources() const | 71 bool CSSFontFaceSrcValue::hasFailedOrCanceledSubresources() const |
| 72 { | 72 { |
| 73 return m_fetched && m_fetched->loadFailedOrCanceled(); | 73 return m_fetched && m_fetched->loadFailedOrCanceled(); |
| 74 } | 74 } |
| 75 | 75 |
| 76 static bool shouldSetCrossOriginAccessControl(const KURL& resource) | 76 static void setCrossOriginAccessControl(FetchRequest& request, SecurityOrigin* s ecurityOrigin) |
| 77 { | 77 { |
| 78 // Local fonts are accessible from file: URLs even when | 78 // Local fonts are accessible from file: URLs even when |
| 79 // allowFileAccessFromFileURLs is false. | 79 // allowFileAccessFromFileURLs is false. |
| 80 if (resource.isLocalFile()) | 80 if (request.url().isLocalFile()) |
| 81 return false; | 81 return; |
| 82 return true; | 82 |
| 83 bool sameOriginRequest = securityOrigin->canRequestNoSuborigin(request.url() ); | |
|
sof
2015/08/20 14:56:58
I see what this is based on, but should we rephras
Kunihiko Sakamoto
2015/08/21 01:37:06
Done.
| |
| 84 request.setCrossOriginAccessControl( | |
| 85 securityOrigin, sameOriginRequest ? AllowStoredCredentials : DoNotAllowS toredCredentials, | |
| 86 ClientDidNotRequestCredentials); | |
| 83 } | 87 } |
| 84 | 88 |
| 85 FontResource* CSSFontFaceSrcValue::fetch(Document* document) | 89 FontResource* CSSFontFaceSrcValue::fetch(Document* document) |
| 86 { | 90 { |
| 87 if (!m_fetched) { | 91 if (!m_fetched) { |
| 88 FetchRequest request(ResourceRequest(document->completeURL(m_resource)), FetchInitiatorTypeNames::css); | 92 FetchRequest request(ResourceRequest(document->completeURL(m_resource)), FetchInitiatorTypeNames::css); |
| 89 request.setContentSecurityCheck(m_shouldCheckContentSecurityPolicy); | 93 request.setContentSecurityCheck(m_shouldCheckContentSecurityPolicy); |
| 90 SecurityOrigin* securityOrigin = document->securityOrigin(); | 94 SecurityOrigin* securityOrigin = document->securityOrigin(); |
| 91 if (shouldSetCrossOriginAccessControl(request.url())) | 95 setCrossOriginAccessControl(request, securityOrigin); |
| 92 request.setCrossOriginAccessControl(securityOrigin, DoNotAllowStored Credentials); | |
| 93 request.mutableResourceRequest().setHTTPReferrer(SecurityPolicy::generat eReferrer(m_referrer.referrerPolicy, request.url(), m_referrer.referrer)); | 96 request.mutableResourceRequest().setHTTPReferrer(SecurityPolicy::generat eReferrer(m_referrer.referrerPolicy, request.url(), m_referrer.referrer)); |
| 94 m_fetched = FontResource::fetch(request, document->fetcher()); | 97 m_fetched = FontResource::fetch(request, document->fetcher()); |
| 95 } else { | 98 } else { |
| 96 // FIXME: CSSFontFaceSrcValue::fetch is invoked when @font-face rule | 99 // FIXME: CSSFontFaceSrcValue::fetch is invoked when @font-face rule |
| 97 // is processed by StyleResolver / StyleEngine. | 100 // is processed by StyleResolver / StyleEngine. |
| 98 restoreCachedResourceIfNeeded(document); | 101 restoreCachedResourceIfNeeded(document); |
| 99 } | 102 } |
| 100 return m_fetched.get(); | 103 return m_fetched.get(); |
| 101 } | 104 } |
| 102 | 105 |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 115 m_fetched->lastResourceRequest().url(), MixedContentChecker::SendReport) ; | 118 m_fetched->lastResourceRequest().url(), MixedContentChecker::SendReport) ; |
| 116 document->fetcher()->requestLoadStarted(m_fetched.get(), request, ResourceFe tcher::ResourceLoadingFromCache); | 119 document->fetcher()->requestLoadStarted(m_fetched.get(), request, ResourceFe tcher::ResourceLoadingFromCache); |
| 117 } | 120 } |
| 118 | 121 |
| 119 bool CSSFontFaceSrcValue::equals(const CSSFontFaceSrcValue& other) const | 122 bool CSSFontFaceSrcValue::equals(const CSSFontFaceSrcValue& other) const |
| 120 { | 123 { |
| 121 return m_isLocal == other.m_isLocal && m_format == other.m_format && m_resou rce == other.m_resource; | 124 return m_isLocal == other.m_isLocal && m_format == other.m_format && m_resou rce == other.m_resource; |
| 122 } | 125 } |
| 123 | 126 |
| 124 } | 127 } |
| OLD | NEW |