Switch all WebKit API related to favicons from WebIconDatabase over to new WebCore...
[WebKit-https.git] / Source / WebCore / loader / EmptyClients.cpp
1 /*
2  * Copyright (C) 2006 Eric Seidel <eric@webkit.org>
3  * Copyright (C) 2008-2017 Apple Inc. All rights reserved.
4  * Copyright (C) Research In Motion Limited 2011. All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
16  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
19  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
20  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
22  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
23  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
26  */
27
28 #include "config.h"
29 #include "EmptyClients.h"
30
31 #include "ApplicationCacheStorage.h"
32 #include "BackForwardClient.h"
33 #include "ColorChooser.h"
34 #include "ContextMenuClient.h"
35 #include "DatabaseProvider.h"
36 #include "DiagnosticLoggingClient.h"
37 #include "DocumentFragment.h"
38 #include "DocumentLoader.h"
39 #include "DragClient.h"
40 #include "EditorClient.h"
41 #include "FileChooser.h"
42 #include "FormState.h"
43 #include "Frame.h"
44 #include "FrameLoaderClient.h"
45 #include "FrameNetworkingContext.h"
46 #include "HTMLFormElement.h"
47 #include "InProcessIDBServer.h"
48 #include "InspectorClient.h"
49 #include "NetworkStorageSession.h"
50 #include "Page.h"
51 #include "PageConfiguration.h"
52 #include "PaymentCoordinatorClient.h"
53 #include "PluginInfoProvider.h"
54 #include "ProgressTrackerClient.h"
55 #include "SecurityOriginData.h"
56 #include "StorageArea.h"
57 #include "StorageNamespace.h"
58 #include "StorageNamespaceProvider.h"
59 #include "StorageType.h"
60 #include "TextCheckerClient.h"
61 #include "ThreadableWebSocketChannel.h"
62 #include "UserContentProvider.h"
63 #include "VisitedLinkStore.h"
64 #include <heap/HeapInlines.h>
65 #include <wtf/NeverDestroyed.h>
66
67 #if ENABLE(CONTENT_EXTENSIONS)
68 #include "CompiledContentExtension.h"
69 #endif
70
71 #if USE(QUICK_LOOK)
72 #include "PreviewLoaderClient.h"
73 #endif
74
75 namespace WebCore {
76
77 class UserMessageHandlerDescriptor;
78
79 class EmptyBackForwardClient final : public BackForwardClient {
80     void addItem(Ref<HistoryItem>&&) final { }
81     void goToItem(HistoryItem*) final { }
82     HistoryItem* itemAtIndex(int) final { return nullptr; }
83     int backListCount() final { return 0; }
84     int forwardListCount() final { return 0; }
85     void close() final { }
86 };
87
88 #if ENABLE(CONTEXT_MENUS)
89
90 class EmptyContextMenuClient final : public ContextMenuClient {
91     void contextMenuDestroyed() final { }
92
93     void downloadURL(const URL&) final { }
94     void searchWithGoogle(const Frame*) final { }
95     void lookUpInDictionary(Frame*) final { }
96     bool isSpeaking() final { return false; }
97     void speak(const String&) final { }
98     void stopSpeaking() final { }
99
100 #if PLATFORM(COCOA)
101     void searchWithSpotlight() final { }
102 #endif
103
104 #if USE(ACCESSIBILITY_CONTEXT_MENUS)
105     void showContextMenu() final { }
106 #endif
107 };
108
109 #endif // ENABLE(CONTEXT_MENUS)
110
111 class EmptyDatabaseProvider final : public DatabaseProvider {
112 #if ENABLE(INDEXED_DATABASE)
113     IDBClient::IDBConnectionToServer& idbConnectionToServerForSession(const SessionID&) final
114     {
115         static NeverDestroyed<Ref<InProcessIDBServer>> sharedConnection(InProcessIDBServer::create());
116         return sharedConnection.get()->connectionToServer();
117     }
118 #endif
119 };
120
121 class EmptyDiagnosticLoggingClient final : public DiagnosticLoggingClient {
122     void logDiagnosticMessage(const String&, const String&, ShouldSample) final { }
123     void logDiagnosticMessageWithResult(const String&, const String&, DiagnosticLoggingResultType, ShouldSample) final { }
124     void logDiagnosticMessageWithValue(const String&, const String&, double, unsigned, ShouldSample) final { }
125     void logDiagnosticMessageWithEnhancedPrivacy(const String&, const String&, ShouldSample) final { }
126 };
127
128 #if ENABLE(DRAG_SUPPORT)
129
130 class EmptyDragClient final : public DragClient {
131     void willPerformDragDestinationAction(DragDestinationAction, const DragData&) final { }
132     void willPerformDragSourceAction(DragSourceAction, const IntPoint&, DataTransfer&) final { }
133     DragSourceAction dragSourceActionMaskForPoint(const IntPoint&) final { return DragSourceActionNone; }
134     void startDrag(DragItem, DataTransfer&, Frame&) final { }
135     void dragControllerDestroyed() final { }
136 };
137
138 #endif // ENABLE(DRAG_SUPPORT)
139
140 class EmptyEditorClient final : public EditorClient {
141     WTF_MAKE_FAST_ALLOCATED;
142
143 public:
144     EmptyEditorClient() = default;
145
146 private:
147     bool shouldDeleteRange(Range*) final { return false; }
148     bool smartInsertDeleteEnabled() final { return false; }
149     bool isSelectTrailingWhitespaceEnabled() const final { return false; }
150     bool isContinuousSpellCheckingEnabled() final { return false; }
151     void toggleContinuousSpellChecking() final { }
152     bool isGrammarCheckingEnabled() final { return false; }
153     void toggleGrammarChecking() final { }
154     int spellCheckerDocumentTag() final { return -1; }
155
156     bool shouldBeginEditing(Range*) final { return false; }
157     bool shouldEndEditing(Range*) final { return false; }
158     bool shouldInsertNode(Node*, Range*, EditorInsertAction) final { return false; }
159     bool shouldInsertText(const String&, Range*, EditorInsertAction) final { return false; }
160     bool shouldChangeSelectedRange(Range*, Range*, EAffinity, bool) final { return false; }
161
162     bool shouldApplyStyle(StyleProperties*, Range*) final { return false; }
163     void didApplyStyle() final { }
164     bool shouldMoveRangeAfterDelete(Range*, Range*) final { return false; }
165
166     void didBeginEditing() final { }
167     void respondToChangedContents() final { }
168     void respondToChangedSelection(Frame*) final { }
169     void didChangeSelectionAndUpdateLayout() final { }
170     void updateEditorStateAfterLayoutIfEditabilityChanged() final { }
171     void discardedComposition(Frame*) final { }
172     void canceledComposition() final { }
173     void didEndEditing() final { }
174     void willWriteSelectionToPasteboard(Range*) final { }
175     void didWriteSelectionToPasteboard() final { }
176     void getClientPasteboardDataForRange(Range*, Vector<String>&, Vector<RefPtr<SharedBuffer>>&) final { }
177     void requestCandidatesForSelection(const VisibleSelection&) final { }
178     void handleAcceptedCandidateWithSoftSpaces(TextCheckingResult) final { }
179
180     void registerUndoStep(UndoStep&) final;
181     void registerRedoStep(UndoStep&) final;
182     void clearUndoRedoOperations() final { }
183
184     bool canCopyCut(Frame*, bool defaultValue) const final { return defaultValue; }
185     bool canPaste(Frame*, bool defaultValue) const final { return defaultValue; }
186     bool canUndo() const final { return false; }
187     bool canRedo() const final { return false; }
188
189     void undo() final { }
190     void redo() final { }
191
192     void handleKeyboardEvent(KeyboardEvent*) final { }
193     void handleInputMethodKeydown(KeyboardEvent*) final { }
194
195     void textFieldDidBeginEditing(Element*) final { }
196     void textFieldDidEndEditing(Element*) final { }
197     void textDidChangeInTextField(Element*) final { }
198     bool doTextFieldCommandFromEvent(Element*, KeyboardEvent*) final { return false; }
199     void textWillBeDeletedInTextField(Element*) final { }
200     void textDidChangeInTextArea(Element*) final { }
201     void overflowScrollPositionChanged() final { }
202
203 #if PLATFORM(IOS)
204     void startDelayingAndCoalescingContentChangeNotifications() final { }
205     void stopDelayingAndCoalescingContentChangeNotifications() final { }
206     void writeDataToPasteboard(NSDictionary*) final { }
207     NSArray* supportedPasteboardTypesForCurrentSelection() final { return nullptr; }
208     NSArray* readDataFromPasteboard(NSString*, int) final { return nullptr; }
209     bool hasRichlyEditableSelection() final { return false; }
210     int getPasteboardItemsCount() final { return 0; }
211     RefPtr<DocumentFragment> documentFragmentFromDelegate(int) final { return nullptr; }
212     bool performsTwoStepPaste(DocumentFragment*) final { return false; }
213     int pasteboardChangeCount() final { return 0; }
214 #endif
215
216     bool performTwoStepDrop(DocumentFragment&, Range&, bool) final { return false; }
217
218 #if PLATFORM(COCOA)
219     NSString *userVisibleString(NSURL *) final { return nullptr; }
220     void setInsertionPasteboard(const String&) final { };
221     NSURL *canonicalizeURL(NSURL *) final { return nullptr; }
222     NSURL *canonicalizeURLString(NSString *) final { return nullptr; }
223 #endif
224
225 #if USE(APPKIT)
226     void uppercaseWord() final { }
227     void lowercaseWord() final { }
228     void capitalizeWord() final { }
229 #endif
230
231 #if USE(AUTOMATIC_TEXT_REPLACEMENT)
232     void showSubstitutionsPanel(bool) final { }
233     bool substitutionsPanelIsShowing() final { return false; }
234     void toggleSmartInsertDelete() final { }
235     bool isAutomaticQuoteSubstitutionEnabled() final { return false; }
236     void toggleAutomaticQuoteSubstitution() final { }
237     bool isAutomaticLinkDetectionEnabled() final { return false; }
238     void toggleAutomaticLinkDetection() final { }
239     bool isAutomaticDashSubstitutionEnabled() final { return false; }
240     void toggleAutomaticDashSubstitution() final { }
241     bool isAutomaticTextReplacementEnabled() final { return false; }
242     void toggleAutomaticTextReplacement() final { }
243     bool isAutomaticSpellingCorrectionEnabled() final { return false; }
244     void toggleAutomaticSpellingCorrection() final { }
245 #endif
246
247 #if PLATFORM(GTK)
248     bool shouldShowUnicodeMenu() final { return false; }
249 #endif
250
251     TextCheckerClient* textChecker() final { return &m_textCheckerClient; }
252
253     void updateSpellingUIWithGrammarString(const String&, const GrammarDetail&) final { }
254     void updateSpellingUIWithMisspelledWord(const String&) final { }
255     void showSpellingUI(bool) final { }
256     bool spellingUIIsShowing() final { return false; }
257
258     void willSetInputMethodState() final { }
259     void setInputMethodState(bool) final { }
260
261     class EmptyTextCheckerClient final : public TextCheckerClient {
262         bool shouldEraseMarkersAfterChangeSelection(TextCheckingType) const final { return true; }
263         void ignoreWordInSpellDocument(const String&) final { }
264         void learnWord(const String&) final { }
265         void checkSpellingOfString(StringView, int*, int*) final { }
266         String getAutoCorrectSuggestionForMisspelledWord(const String&) final { return { }; }
267         void checkGrammarOfString(StringView, Vector<GrammarDetail>&, int*, int*) final { }
268
269 #if USE(UNIFIED_TEXT_CHECKING)
270         Vector<TextCheckingResult> checkTextOfParagraph(StringView, TextCheckingTypeMask, const VisibleSelection&) final { return Vector<TextCheckingResult>(); }
271 #endif
272
273         void getGuessesForWord(const String&, const String&, const VisibleSelection&, Vector<String>&) final { }
274         void requestCheckingOfString(TextCheckingRequest&, const VisibleSelection&) final;
275     };
276
277     EmptyTextCheckerClient m_textCheckerClient;
278 };
279
280 class EmptyFrameLoaderClient final : public FrameLoaderClient {
281     void frameLoaderDestroyed() final { }
282
283     bool hasWebView() const final { return true; } // mainly for assertions
284
285     void makeRepresentation(DocumentLoader*) final { }
286 #if PLATFORM(IOS)
287     bool forceLayoutOnRestoreFromPageCache() final { return false; }
288 #endif
289     void forceLayoutForNonHTML() final { }
290
291     void setCopiesOnScroll() final { }
292
293     void detachedFromParent2() final { }
294     void detachedFromParent3() final { }
295
296     void convertMainResourceLoadToDownload(DocumentLoader*, SessionID, const ResourceRequest&, const ResourceResponse&) final { }
297
298     void assignIdentifierToInitialRequest(unsigned long, DocumentLoader*, const ResourceRequest&) final { }
299     bool shouldUseCredentialStorage(DocumentLoader*, unsigned long) final { return false; }
300     void dispatchWillSendRequest(DocumentLoader*, unsigned long, ResourceRequest&, const ResourceResponse&) final { }
301     void dispatchDidReceiveAuthenticationChallenge(DocumentLoader*, unsigned long, const AuthenticationChallenge&) final { }
302 #if USE(PROTECTION_SPACE_AUTH_CALLBACK)
303     bool canAuthenticateAgainstProtectionSpace(DocumentLoader*, unsigned long, const ProtectionSpace&) final { return false; }
304 #endif
305
306 #if PLATFORM(IOS)
307     RetainPtr<CFDictionaryRef> connectionProperties(DocumentLoader*, unsigned long) final { return nullptr; }
308 #endif
309
310     void dispatchDidReceiveResponse(DocumentLoader*, unsigned long, const ResourceResponse&) final { }
311     void dispatchDidReceiveContentLength(DocumentLoader*, unsigned long, int) final { }
312     void dispatchDidFinishLoading(DocumentLoader*, unsigned long) final { }
313 #if ENABLE(DATA_DETECTION)
314     void dispatchDidFinishDataDetection(NSArray *) final { }
315 #endif
316     void dispatchDidFailLoading(DocumentLoader*, unsigned long, const ResourceError&) final { }
317     bool dispatchDidLoadResourceFromMemoryCache(DocumentLoader*, const ResourceRequest&, const ResourceResponse&, int) final { return false; }
318
319     void dispatchDidDispatchOnloadEvents() final { }
320     void dispatchDidReceiveServerRedirectForProvisionalLoad() final { }
321     void dispatchDidCancelClientRedirect() final { }
322     void dispatchWillPerformClientRedirect(const URL&, double, double) final { }
323     void dispatchDidChangeLocationWithinPage() final { }
324     void dispatchDidPushStateWithinPage() final { }
325     void dispatchDidReplaceStateWithinPage() final { }
326     void dispatchDidPopStateWithinPage() final { }
327     void dispatchWillClose() final { }
328     void dispatchDidStartProvisionalLoad() final { }
329     void dispatchDidReceiveTitle(const StringWithDirection&) final { }
330     void dispatchDidCommitLoad(std::optional<HasInsecureContent>) final { }
331     void dispatchDidFailProvisionalLoad(const ResourceError&) final { }
332     void dispatchDidFailLoad(const ResourceError&) final { }
333     void dispatchDidFinishDocumentLoad() final { }
334     void dispatchDidFinishLoad() final { }
335     void dispatchDidReachLayoutMilestone(LayoutMilestones) final { }
336
337     Frame* dispatchCreatePage(const NavigationAction&) final { return nullptr; }
338     void dispatchShow() final { }
339
340     void dispatchDecidePolicyForResponse(const ResourceResponse&, const ResourceRequest&, FramePolicyFunction&&) final { }
341     void dispatchDecidePolicyForNewWindowAction(const NavigationAction&, const ResourceRequest&, FormState*, const String&, FramePolicyFunction&&) final;
342     void dispatchDecidePolicyForNavigationAction(const NavigationAction&, const ResourceRequest&, FormState*, FramePolicyFunction&&) final;
343     void cancelPolicyCheck() final { }
344
345     void dispatchUnableToImplementPolicy(const ResourceError&) final { }
346
347     void dispatchWillSendSubmitEvent(Ref<FormState>&&) final;
348     void dispatchWillSubmitForm(FormState&, FramePolicyFunction&&) final;
349
350     void revertToProvisionalState(DocumentLoader*) final { }
351     void setMainDocumentError(DocumentLoader*, const ResourceError&) final { }
352
353     void setMainFrameDocumentReady(bool) final { }
354
355     void startDownload(const ResourceRequest&, const String&) final { }
356
357     void willChangeTitle(DocumentLoader*) final { }
358     void didChangeTitle(DocumentLoader*) final { }
359
360     void willReplaceMultipartContent() final { }
361     void didReplaceMultipartContent() final { }
362
363     void committedLoad(DocumentLoader*, const char*, int) final { }
364     void finishedLoading(DocumentLoader*) final { }
365
366     ResourceError cancelledError(const ResourceRequest&) final { return { ResourceError::Type::Cancellation }; }
367     ResourceError blockedError(const ResourceRequest&) final { return { }; }
368     ResourceError blockedByContentBlockerError(const ResourceRequest&) final { return { }; }
369     ResourceError cannotShowURLError(const ResourceRequest&) final { return { }; }
370     ResourceError interruptedForPolicyChangeError(const ResourceRequest&) final { return { }; }
371 #if ENABLE(CONTENT_FILTERING)
372     ResourceError blockedByContentFilterError(const ResourceRequest&) final { return { }; }
373 #endif
374
375     ResourceError cannotShowMIMETypeError(const ResourceResponse&) final { return { }; }
376     ResourceError fileDoesNotExistError(const ResourceResponse&) final { return { }; }
377     ResourceError pluginWillHandleLoadError(const ResourceResponse&) final { return { }; }
378
379     bool shouldFallBack(const ResourceError&) final { return false; }
380
381     bool canHandleRequest(const ResourceRequest&) const final { return false; }
382     bool canShowMIMEType(const String&) const final { return false; }
383     bool canShowMIMETypeAsHTML(const String&) const final { return false; }
384     bool representationExistsForURLScheme(const String&) const final { return false; }
385     String generatedMIMETypeForURLScheme(const String&) const final { return emptyString(); }
386
387     void frameLoadCompleted() final { }
388     void restoreViewState() final { }
389     void provisionalLoadStarted() final { }
390     void didFinishLoad() final { }
391     void prepareForDataSourceReplacement() final { }
392
393     Ref<DocumentLoader> createDocumentLoader(const ResourceRequest&, const SubstituteData&) final;
394     void updateCachedDocumentLoader(DocumentLoader&) final { }
395     void setTitle(const StringWithDirection&, const URL&) final { }
396
397     String userAgent(const URL&) final { return emptyString(); }
398
399     void savePlatformDataToCachedFrame(CachedFrame*) final { }
400     void transitionToCommittedFromCachedFrame(CachedFrame*) final { }
401 #if PLATFORM(IOS)
402     void didRestoreFrameHierarchyForCachedFrame() final { }
403 #endif
404     void transitionToCommittedForNewPage() final { }
405
406     void didSaveToPageCache() final { }
407     void didRestoreFromPageCache() final { }
408
409     void dispatchDidBecomeFrameset(bool) final { }
410
411     void updateGlobalHistory() final { }
412     void updateGlobalHistoryRedirectLinks() final { }
413     bool shouldGoToHistoryItem(HistoryItem*) const final { return false; }
414     void updateGlobalHistoryItemForPage() final { }
415     void saveViewStateToItem(HistoryItem&) final { }
416     bool canCachePage() const final { return false; }
417     void didDisplayInsecureContent() final { }
418     void didRunInsecureContent(SecurityOrigin&, const URL&) final { }
419     void didDetectXSS(const URL&, bool) final { }
420     RefPtr<Frame> createFrame(const URL&, const String&, HTMLFrameOwnerElement&, const String&, bool, int, int) final;
421     RefPtr<Widget> createPlugin(const IntSize&, HTMLPlugInElement&, const URL&, const Vector<String>&, const Vector<String>&, const String&, bool) final;
422     void recreatePlugin(Widget*) final;
423     RefPtr<Widget> createJavaAppletWidget(const IntSize&, HTMLAppletElement&, const URL&, const Vector<String>&, const Vector<String>&) final;
424
425     ObjectContentType objectContentType(const URL&, const String&) final { return ObjectContentType::None; }
426     String overrideMediaType() const final { return { }; }
427
428     void redirectDataToPlugin(Widget&) final { }
429     void dispatchDidClearWindowObjectInWorld(DOMWrapperWorld&) final { }
430
431 #if PLATFORM(COCOA)
432     RemoteAXObjectRef accessibilityRemoteObject() final { return nullptr; }
433     NSCachedURLResponse *willCacheResponse(DocumentLoader*, unsigned long, NSCachedURLResponse *response) const final { return response; }
434 #endif
435
436 #if PLATFORM(WIN) && USE(CFURLCONNECTION)
437     bool shouldCacheResponse(DocumentLoader*, unsigned long, const ResourceResponse&, const unsigned char*, unsigned long long) final { return true; }
438 #endif
439
440     Ref<FrameNetworkingContext> createNetworkingContext() final;
441
442 #if ENABLE(REQUEST_AUTOCOMPLETE)
443     void didRequestAutocomplete(Ref<FormState>&&) final { }
444 #endif
445
446     bool isEmptyFrameLoaderClient() final { return true; }
447     void prefetchDNS(const String&) final { }
448
449 #if USE(QUICK_LOOK)
450     RefPtr<PreviewLoaderClient> createPreviewLoaderClient(const String&, const String&) final { return nullptr; }
451 #endif
452 };
453
454 class EmptyFrameNetworkingContext final : public FrameNetworkingContext {
455 public:
456     static Ref<EmptyFrameNetworkingContext> create() { return adoptRef(*new EmptyFrameNetworkingContext); }
457
458 private:
459     EmptyFrameNetworkingContext();
460
461     bool shouldClearReferrerOnHTTPSToHTTPRedirect() const { return true; }
462     NetworkStorageSession& storageSession() const final { return NetworkStorageSession::defaultStorageSession(); }
463
464 #if PLATFORM(COCOA)
465     bool localFileContentSniffingEnabled() const { return false; }
466     SchedulePairHashSet* scheduledRunLoopPairs() const { return nullptr; }
467     RetainPtr<CFDataRef> sourceApplicationAuditData() const { return nullptr; };
468 #endif
469
470 #if PLATFORM(COCOA) || PLATFORM(WIN)
471     ResourceError blockedError(const ResourceRequest&) const final { return { }; }
472 #endif
473 };
474
475 class EmptyInspectorClient final : public InspectorClient {
476     void inspectedPageDestroyed() final { }
477     Inspector::FrontendChannel* openLocalFrontend(InspectorController*) final { return nullptr; }
478     void bringFrontendToFront() final { }
479     void highlight() final { }
480     void hideHighlight() final { }
481 };
482
483 #if ENABLE(APPLE_PAY)
484
485 class EmptyPaymentCoordinatorClient final : public PaymentCoordinatorClient {
486     bool supportsVersion(unsigned) final { return false; }
487     bool canMakePayments() final { return false; }
488     void canMakePaymentsWithActiveCard(const String&, const String&, WTF::Function<void(bool)>&& completionHandler) final { callOnMainThread([completionHandler = WTFMove(completionHandler)] { completionHandler(false); }); }
489     void openPaymentSetup(const String&, const String&, WTF::Function<void(bool)>&& completionHandler) final { callOnMainThread([completionHandler = WTFMove(completionHandler)] { completionHandler(false); }); }
490     bool showPaymentUI(const URL&, const Vector<URL>&, const PaymentRequest&) final { return false; }
491     void completeMerchantValidation(const PaymentMerchantSession&) final { }
492     void completeShippingMethodSelection(std::optional<ShippingMethodUpdate>&&) final { }
493     void completeShippingContactSelection(std::optional<ShippingContactUpdate>&&) final { }
494     void completePaymentMethodSelection(std::optional<PaymentMethodUpdate>&&) final { }
495     void completePaymentSession(std::optional<PaymentAuthorizationResult>&&) final { }
496     void cancelPaymentSession() final { }
497     void abortPaymentSession() final { }
498     void paymentCoordinatorDestroyed() final { }
499 };
500
501 #endif
502
503 class EmptyPluginInfoProvider final : public PluginInfoProvider {
504     void refreshPlugins() final { };
505     void getPluginInfo(Page&, Vector<PluginInfo>&) final { }
506     void getWebVisiblePluginInfo(Page&, Vector<PluginInfo>&) final { }
507 };
508
509 class EmptyPopupMenu : public PopupMenu {
510 public:
511     EmptyPopupMenu() = default;
512 private:
513     void show(const IntRect&, FrameView*, int) final { }
514     void hide() final { }
515     void updateFromElement() final { }
516     void disconnectClient() final { }
517 };
518
519 class EmptyProgressTrackerClient final : public ProgressTrackerClient {
520     void willChangeEstimatedProgress() final { }
521     void didChangeEstimatedProgress() final { }
522     void progressStarted(Frame&) final { }
523     void progressEstimateChanged(Frame&) final { }
524     void progressFinished(Frame&) final { }
525 };
526
527 class EmptySearchPopupMenu : public SearchPopupMenu {
528 public:
529     EmptySearchPopupMenu()
530         : m_popup(adoptRef(*new EmptyPopupMenu))
531     {
532     }
533
534 private:
535     PopupMenu* popupMenu() final { return m_popup.ptr(); }
536     void saveRecentSearches(const AtomicString&, const Vector<RecentSearch>&) final { }
537     void loadRecentSearches(const AtomicString&, Vector<RecentSearch>&) final { }
538     bool enabled() final { return false; }
539
540     Ref<EmptyPopupMenu> m_popup;
541 };
542
543 class EmptyStorageNamespaceProvider final : public StorageNamespaceProvider {
544     struct EmptyStorageArea : public StorageArea {
545         unsigned length() final { return 0; }
546         String key(unsigned) final { return { }; }
547         String item(const String&) final { return { }; }
548         void setItem(Frame*, const String&, const String&, bool&) final { }
549         void removeItem(Frame*, const String&) final { }
550         void clear(Frame*) final { }
551         bool contains(const String&) final { return false; }
552         bool canAccessStorage(Frame*) final { return false; }
553         StorageType storageType() const final { return StorageType::Local; }
554         size_t memoryBytesUsedByCache() final { return 0; }
555         SecurityOriginData securityOrigin() const final { return { }; }
556     };
557
558     struct EmptyStorageNamespace final : public StorageNamespace {
559         RefPtr<StorageArea> storageArea(const SecurityOriginData&) final { return adoptRef(*new EmptyStorageArea); }
560         RefPtr<StorageNamespace> copy(Page*) final { return adoptRef(*new EmptyStorageNamespace); }
561     };
562
563     RefPtr<StorageNamespace> createSessionStorageNamespace(Page&, unsigned) final;
564     RefPtr<StorageNamespace> createLocalStorageNamespace(unsigned) final;
565     RefPtr<StorageNamespace> createEphemeralLocalStorageNamespace(Page&, unsigned) final;
566     RefPtr<StorageNamespace> createTransientLocalStorageNamespace(SecurityOrigin&, unsigned) final;
567 };
568
569 class EmptyUserContentProvider final : public UserContentProvider {
570     void forEachUserScript(Function<void(DOMWrapperWorld&, const UserScript&)>&&) const final { }
571     void forEachUserStyleSheet(Function<void(const UserStyleSheet&)>&&) const final { }
572 #if ENABLE(USER_MESSAGE_HANDLERS)
573     void forEachUserMessageHandler(Function<void(const UserMessageHandlerDescriptor&)>&&) const final { }
574 #endif
575 #if ENABLE(CONTENT_EXTENSIONS)
576     ContentExtensions::ContentExtensionsBackend& userContentExtensionBackend() final { static NeverDestroyed<ContentExtensions::ContentExtensionsBackend> backend; return backend.get(); };
577 #endif
578 };
579
580 class EmptyVisitedLinkStore final : public VisitedLinkStore {
581     bool isLinkVisited(Page&, LinkHash, const URL&, const AtomicString&) final { return false; }
582     void addVisitedLink(Page&, LinkHash) final { }
583 };
584
585 RefPtr<PopupMenu> EmptyChromeClient::createPopupMenu(PopupMenuClient&) const
586 {
587     return adoptRef(*new EmptyPopupMenu);
588 }
589
590 RefPtr<SearchPopupMenu> EmptyChromeClient::createSearchPopupMenu(PopupMenuClient&) const
591 {
592     return adoptRef(*new EmptySearchPopupMenu);
593 }
594
595 #if ENABLE(INPUT_TYPE_COLOR)
596
597 std::unique_ptr<ColorChooser> EmptyChromeClient::createColorChooser(ColorChooserClient&, const Color&)
598 {
599     return nullptr;
600 }
601
602 #endif
603
604 void EmptyChromeClient::runOpenPanel(Frame&, FileChooser&)
605 {
606 }
607
608 void EmptyFrameLoaderClient::dispatchDecidePolicyForNewWindowAction(const NavigationAction&, const ResourceRequest&, FormState*, const String&, FramePolicyFunction&&)
609 {
610 }
611
612 void EmptyFrameLoaderClient::dispatchDecidePolicyForNavigationAction(const NavigationAction&, const ResourceRequest&, FormState*, FramePolicyFunction&&)
613 {
614 }
615
616 void EmptyFrameLoaderClient::dispatchWillSendSubmitEvent(Ref<FormState>&&)
617 {
618 }
619
620 void EmptyFrameLoaderClient::dispatchWillSubmitForm(FormState&, FramePolicyFunction&&)
621 {
622 }
623
624 Ref<DocumentLoader> EmptyFrameLoaderClient::createDocumentLoader(const ResourceRequest& request, const SubstituteData& substituteData)
625 {
626     return DocumentLoader::create(request, substituteData);
627 }
628
629 RefPtr<Frame> EmptyFrameLoaderClient::createFrame(const URL&, const String&, HTMLFrameOwnerElement&, const String&, bool, int, int)
630 {
631     return nullptr;
632 }
633
634 RefPtr<Widget> EmptyFrameLoaderClient::createPlugin(const IntSize&, HTMLPlugInElement&, const URL&, const Vector<String>&, const Vector<String>&, const String&, bool)
635 {
636     return nullptr;
637 }
638
639 void EmptyFrameLoaderClient::recreatePlugin(Widget*)
640 {
641 }
642
643 RefPtr<Widget> EmptyFrameLoaderClient::createJavaAppletWidget(const IntSize&, HTMLAppletElement&, const URL&, const Vector<String>&, const Vector<String>&)
644 {
645     return nullptr;
646 }
647
648 inline EmptyFrameNetworkingContext::EmptyFrameNetworkingContext()
649     : FrameNetworkingContext { nullptr }
650 {
651 }
652
653 Ref<FrameNetworkingContext> EmptyFrameLoaderClient::createNetworkingContext()
654 {
655     return EmptyFrameNetworkingContext::create();
656 }
657
658 void EmptyEditorClient::EmptyTextCheckerClient::requestCheckingOfString(TextCheckingRequest&, const VisibleSelection&)
659 {
660 }
661
662 void EmptyEditorClient::registerUndoStep(UndoStep&)
663 {
664 }
665
666 void EmptyEditorClient::registerRedoStep(UndoStep&)
667 {
668 }
669
670 RefPtr<StorageNamespace> EmptyStorageNamespaceProvider::createSessionStorageNamespace(Page&, unsigned)
671 {
672     return adoptRef(*new EmptyStorageNamespace);
673 }
674
675 RefPtr<StorageNamespace> EmptyStorageNamespaceProvider::createLocalStorageNamespace(unsigned)
676 {
677     return adoptRef(*new EmptyStorageNamespace);
678 }
679
680 RefPtr<StorageNamespace> EmptyStorageNamespaceProvider::createEphemeralLocalStorageNamespace(Page&, unsigned)
681 {
682     return adoptRef(*new EmptyStorageNamespace);
683 }
684
685 RefPtr<StorageNamespace> EmptyStorageNamespaceProvider::createTransientLocalStorageNamespace(SecurityOrigin&, unsigned)
686 {
687     return adoptRef(*new EmptyStorageNamespace);
688 }
689
690 void fillWithEmptyClients(PageConfiguration& pageConfiguration)
691 {
692     static NeverDestroyed<EmptyChromeClient> dummyChromeClient;
693     pageConfiguration.chromeClient = &dummyChromeClient.get();
694
695 #if ENABLE(APPLE_PAY)
696     static NeverDestroyed<EmptyPaymentCoordinatorClient> dummyPaymentCoordinatorClient;
697     pageConfiguration.paymentCoordinatorClient = &dummyPaymentCoordinatorClient.get();
698 #endif
699
700 #if ENABLE(CONTEXT_MENUS)
701     static NeverDestroyed<EmptyContextMenuClient> dummyContextMenuClient;
702     pageConfiguration.contextMenuClient = &dummyContextMenuClient.get();
703 #endif
704
705 #if ENABLE(DRAG_SUPPORT)
706     static NeverDestroyed<EmptyDragClient> dummyDragClient;
707     pageConfiguration.dragClient = &dummyDragClient.get();
708 #endif
709
710     static NeverDestroyed<EmptyInspectorClient> dummyInspectorClient;
711     pageConfiguration.inspectorClient = &dummyInspectorClient.get();
712
713     static NeverDestroyed<EmptyFrameLoaderClient> dummyFrameLoaderClient;
714     pageConfiguration.loaderClientForMainFrame = &dummyFrameLoaderClient.get();
715
716     static NeverDestroyed<EmptyProgressTrackerClient> dummyProgressTrackerClient;
717     pageConfiguration.progressTrackerClient = &dummyProgressTrackerClient.get();
718
719     pageConfiguration.backForwardClient = adoptRef(*new EmptyBackForwardClient);
720     pageConfiguration.diagnosticLoggingClient = std::make_unique<EmptyDiagnosticLoggingClient>();
721
722     pageConfiguration.applicationCacheStorage = ApplicationCacheStorage::create({ }, { });
723     pageConfiguration.databaseProvider = adoptRef(*new EmptyDatabaseProvider);
724     pageConfiguration.pluginInfoProvider = adoptRef(*new EmptyPluginInfoProvider);
725     pageConfiguration.storageNamespaceProvider = adoptRef(*new EmptyStorageNamespaceProvider);
726     pageConfiguration.userContentProvider = adoptRef(*new EmptyUserContentProvider);
727     pageConfiguration.visitedLinkStore = adoptRef(*new EmptyVisitedLinkStore);
728 }
729
730 UniqueRef<EditorClient> createEmptyEditorClient()
731 {
732     return makeUniqueRef<EmptyEditorClient>();
733 }
734
735 DiagnosticLoggingClient& emptyDiagnosticLoggingClient()
736 {
737     static NeverDestroyed<EmptyDiagnosticLoggingClient> client;
738     return client;
739 }
740
741 }