OLD | NEW |
1 /* | 1 /* |
2 Copyright (C) 1998 Lars Knoll (knoll@mpi-hd.mpg.de) | 2 Copyright (C) 1998 Lars Knoll (knoll@mpi-hd.mpg.de) |
3 Copyright (C) 2001 Dirk Mueller <mueller@kde.org> | 3 Copyright (C) 2001 Dirk Mueller <mueller@kde.org> |
4 Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All
rights reserved. | 4 Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All
rights reserved. |
5 Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/ | 5 Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/ |
6 | 6 |
7 This library is free software; you can redistribute it and/or | 7 This library is free software; you can redistribute it and/or |
8 modify it under the terms of the GNU Library General Public | 8 modify it under the terms of the GNU Library General Public |
9 License as published by the Free Software Foundation; either | 9 License as published by the Free Software Foundation; either |
10 version 2 of the License, or (at your option) any later version. | 10 version 2 of the License, or (at your option) any later version. |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
54 class XSLStyleSheetResource; | 54 class XSLStyleSheetResource; |
55 class Document; | 55 class Document; |
56 class DocumentLoader; | 56 class DocumentLoader; |
57 class Frame; | 57 class Frame; |
58 class FrameLoader; | 58 class FrameLoader; |
59 class ImageLoader; | 59 class ImageLoader; |
60 class KURL; | 60 class KURL; |
61 class ResourceTimingInfo; | 61 class ResourceTimingInfo; |
62 class ResourceLoaderSet; | 62 class ResourceLoaderSet; |
63 | 63 |
64 enum CORSEnabled { | |
65 NotCORSEnabled, | |
66 PotentiallyCORSEnabled // Indicates "potentially CORS-enabled fetch" in HTML
standard. | |
67 }; | |
68 | |
69 // The ResourceFetcher provides a per-context interface to the MemoryCache | 64 // The ResourceFetcher provides a per-context interface to the MemoryCache |
70 // and enforces a bunch of security checks and rules for resource revalidation. | 65 // and enforces a bunch of security checks and rules for resource revalidation. |
71 // Its lifetime is roughly per-DocumentLoader, in that it is generally created | 66 // Its lifetime is roughly per-DocumentLoader, in that it is generally created |
72 // in the DocumentLoader constructor and loses its ability to generate network | 67 // in the DocumentLoader constructor and loses its ability to generate network |
73 // requests when the DocumentLoader is destroyed. Documents also hold a | 68 // requests when the DocumentLoader is destroyed. Documents also hold a |
74 // RefPtr<ResourceFetcher> for their lifetime (and will create one if they | 69 // RefPtr<ResourceFetcher> for their lifetime (and will create one if they |
75 // are initialized without a Frame), so a Document can keep a ResourceFetcher | 70 // are initialized without a Frame), so a Document can keep a ResourceFetcher |
76 // alive past detach if scripts still reference the Document. | 71 // alive past detach if scripts still reference the Document. |
77 class ResourceFetcher FINAL : public RefCounted<ResourceFetcher>, public Resourc
eLoaderHost { | 72 class ResourceFetcher FINAL : public RefCounted<ResourceFetcher>, public Resourc
eLoaderHost { |
78 WTF_MAKE_NONCOPYABLE(ResourceFetcher); WTF_MAKE_FAST_ALLOCATED; | 73 WTF_MAKE_NONCOPYABLE(ResourceFetcher); WTF_MAKE_FAST_ALLOCATED; |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
126 void garbageCollectDocumentResources(); | 121 void garbageCollectDocumentResources(); |
127 | 122 |
128 int requestCount() const { return m_requestCount; } | 123 int requestCount() const { return m_requestCount; } |
129 | 124 |
130 bool isPreloaded(const String& urlString) const; | 125 bool isPreloaded(const String& urlString) const; |
131 void clearPreloads(); | 126 void clearPreloads(); |
132 void clearPendingPreloads(); | 127 void clearPendingPreloads(); |
133 void preload(Resource::Type, FetchRequest&, const String& charset); | 128 void preload(Resource::Type, FetchRequest&, const String& charset); |
134 void checkForPendingPreloads(); | 129 void checkForPendingPreloads(); |
135 void printPreloadStats(); | 130 void printPreloadStats(); |
136 bool canAccess(Resource*, CORSEnabled, FetchRequest::OriginRestriction = Fet
chRequest::UseDefaultOriginRestrictionForType); | |
137 | 131 |
138 void setDefersLoading(bool); | 132 void setDefersLoading(bool); |
139 void stopFetching(); | 133 void stopFetching(); |
140 bool isFetching() const; | 134 bool isFetching() const; |
141 | 135 |
142 // ResourceLoaderHost | 136 // ResourceLoaderHost |
143 virtual void incrementRequestCount(const Resource*) OVERRIDE; | 137 virtual void incrementRequestCount(const Resource*) OVERRIDE; |
144 virtual void decrementRequestCount(const Resource*) OVERRIDE; | 138 virtual void decrementRequestCount(const Resource*) OVERRIDE; |
145 virtual void didLoadResource(Resource*) OVERRIDE; | 139 virtual void didLoadResource(Resource*) OVERRIDE; |
146 virtual void redirectReceived(Resource*, const ResourceResponse&) OVERRIDE; | 140 virtual void redirectReceived(Resource*, const ResourceResponse&) OVERRIDE; |
147 virtual void didFinishLoading(const Resource*, double finishTime) OVERRIDE; | 141 virtual void didFinishLoading(const Resource*, double finishTime) OVERRIDE; |
148 virtual void didChangeLoadingPriority(const Resource*, ResourceLoadPriority)
OVERRIDE; | 142 virtual void didChangeLoadingPriority(const Resource*, ResourceLoadPriority)
OVERRIDE; |
149 virtual void didFailLoading(const Resource*, const ResourceError&) OVERRIDE; | 143 virtual void didFailLoading(const Resource*, const ResourceError&) OVERRIDE; |
150 virtual void willSendRequest(unsigned long identifier, ResourceRequest&, con
st ResourceResponse& redirectResponse, const FetchInitiatorInfo&) OVERRIDE; | 144 virtual void willSendRequest(unsigned long identifier, ResourceRequest&, con
st ResourceResponse& redirectResponse, const FetchInitiatorInfo&) OVERRIDE; |
151 virtual void didReceiveResponse(const Resource*, const ResourceResponse&) OV
ERRIDE; | 145 virtual void didReceiveResponse(const Resource*, const ResourceResponse&) OV
ERRIDE; |
152 virtual void didReceiveData(const Resource*, const char* data, int dataLengt
h, int encodedDataLength) OVERRIDE; | 146 virtual void didReceiveData(const Resource*, const char* data, int dataLengt
h, int encodedDataLength) OVERRIDE; |
153 virtual void didDownloadData(const Resource*, int dataLength, int encodedDat
aLength) OVERRIDE; | 147 virtual void didDownloadData(const Resource*, int dataLength, int encodedDat
aLength) OVERRIDE; |
154 virtual void subresourceLoaderFinishedLoadingOnePart(ResourceLoader*) OVERRI
DE; | 148 virtual void subresourceLoaderFinishedLoadingOnePart(ResourceLoader*) OVERRI
DE; |
155 virtual void didInitializeResourceLoader(ResourceLoader*) OVERRIDE; | 149 virtual void didInitializeResourceLoader(ResourceLoader*) OVERRIDE; |
156 virtual void willTerminateResourceLoader(ResourceLoader*) OVERRIDE; | 150 virtual void willTerminateResourceLoader(ResourceLoader*) OVERRIDE; |
157 virtual void willStartLoadingResource(ResourceRequest&) OVERRIDE; | 151 virtual void willStartLoadingResource(ResourceRequest&) OVERRIDE; |
158 virtual bool defersLoading() const OVERRIDE; | 152 virtual bool defersLoading() const OVERRIDE; |
159 virtual bool isLoadedBy(ResourceLoaderHost*) const OVERRIDE; | 153 virtual bool isLoadedBy(ResourceLoaderHost*) const OVERRIDE; |
160 virtual bool shouldRequest(Resource*, const ResourceRequest&, const Resource
LoaderOptions&) OVERRIDE; | 154 virtual bool shouldRequest(Resource*, const ResourceRequest&, const Resource
LoaderOptions&) OVERRIDE; |
| 155 virtual bool canAccessResource(Resource*, const KURL&) const OVERRIDE; |
161 virtual void refResourceLoaderHost() OVERRIDE; | 156 virtual void refResourceLoaderHost() OVERRIDE; |
162 virtual void derefResourceLoaderHost() OVERRIDE; | 157 virtual void derefResourceLoaderHost() OVERRIDE; |
163 | 158 |
164 static const ResourceLoaderOptions& defaultResourceOptions(); | 159 static const ResourceLoaderOptions& defaultResourceOptions(); |
165 private: | 160 private: |
166 | 161 |
167 explicit ResourceFetcher(DocumentLoader*); | 162 explicit ResourceFetcher(DocumentLoader*); |
168 | 163 |
169 bool shouldLoadNewResource(Resource::Type) const; | 164 bool shouldLoadNewResource(Resource::Type) const; |
170 | 165 |
171 ResourcePtr<Resource> requestResource(Resource::Type, FetchRequest&); | 166 ResourcePtr<Resource> requestResource(Resource::Type, FetchRequest&); |
172 ResourcePtr<Resource> revalidateResource(const FetchRequest&, Resource*); | 167 ResourcePtr<Resource> revalidateResource(const FetchRequest&, Resource*); |
173 ResourcePtr<Resource> loadResource(Resource::Type, FetchRequest&, const Stri
ng& charset); | 168 ResourcePtr<Resource> loadResource(Resource::Type, FetchRequest&, const Stri
ng& charset); |
174 void preCacheDataURIImage(const FetchRequest&); | 169 void preCacheDataURIImage(const FetchRequest&); |
175 void preCacheSubstituteDataForMainResource(const FetchRequest&, const Substi
tuteData&); | 170 void preCacheSubstituteDataForMainResource(const FetchRequest&, const Substi
tuteData&); |
176 void storeResourceTimingInitiatorInformation(const ResourcePtr<Resource>&, c
onst FetchRequest&); | 171 void storeResourceTimingInitiatorInformation(const ResourcePtr<Resource>&, c
onst FetchRequest&); |
177 void requestPreload(Resource::Type, FetchRequest&, const String& charset); | 172 void requestPreload(Resource::Type, FetchRequest&, const String& charset); |
178 | 173 |
179 enum RevalidationPolicy { Use, Revalidate, Reload, Load }; | 174 enum RevalidationPolicy { Use, Revalidate, Reload, Load }; |
180 RevalidationPolicy determineRevalidationPolicy(Resource::Type, ResourceReque
st&, bool forPreload, Resource* existingResource, FetchRequest::DeferOption) con
st; | 175 RevalidationPolicy determineRevalidationPolicy(Resource::Type, ResourceReque
st&, bool forPreload, Resource* existingResource, FetchRequest::DeferOption, con
st ResourceLoaderOptions&) const; |
181 | 176 |
182 void determineTargetType(ResourceRequest&, Resource::Type); | 177 void determineTargetType(ResourceRequest&, Resource::Type); |
183 ResourceRequestCachePolicy resourceRequestCachePolicy(const ResourceRequest&
, Resource::Type); | 178 ResourceRequestCachePolicy resourceRequestCachePolicy(const ResourceRequest&
, Resource::Type); |
184 void addAdditionalRequestHeaders(ResourceRequest&, Resource::Type); | 179 void addAdditionalRequestHeaders(ResourceRequest&, Resource::Type); |
185 | 180 |
186 bool canRequest(Resource::Type, const KURL&, const ResourceLoaderOptions&, b
ool forPreload, FetchRequest::OriginRestriction); | 181 bool canRequest(Resource::Type, const KURL&, const ResourceLoaderOptions&, b
ool forPreload, FetchRequest::OriginRestriction) const; |
187 bool checkInsecureContent(Resource::Type, const KURL&, MixedContentBlockingT
reatment) const; | 182 bool checkInsecureContent(Resource::Type, const KURL&, MixedContentBlockingT
reatment) const; |
188 | 183 |
189 static bool resourceNeedsLoad(Resource*, const FetchRequest&, RevalidationPo
licy); | 184 static bool resourceNeedsLoad(Resource*, const FetchRequest&, RevalidationPo
licy); |
190 | 185 |
191 void notifyLoadedFromMemoryCache(Resource*); | 186 void notifyLoadedFromMemoryCache(Resource*); |
192 | 187 |
193 void garbageCollectDocumentResourcesTimerFired(Timer<ResourceFetcher>*); | 188 void garbageCollectDocumentResourcesTimerFired(Timer<ResourceFetcher>*); |
194 void scheduleDocumentResourcesGC(); | 189 void scheduleDocumentResourcesGC(); |
195 | 190 |
196 void resourceTimingReportTimerFired(Timer<ResourceFetcher>*); | 191 void resourceTimingReportTimerFired(Timer<ResourceFetcher>*); |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
251 m_loader->m_allowStaleResources = m_previousState; | 246 m_loader->m_allowStaleResources = m_previousState; |
252 } | 247 } |
253 private: | 248 private: |
254 ResourceFetcher* m_loader; | 249 ResourceFetcher* m_loader; |
255 bool m_previousState; | 250 bool m_previousState; |
256 }; | 251 }; |
257 | 252 |
258 } // namespace WebCore | 253 } // namespace WebCore |
259 | 254 |
260 #endif | 255 #endif |
OLD | NEW |