All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.kklisura.cdt.protocol.commands.Page Maven / Gradle / Ivy

There is a newer version: 4.0.0
Show newest version
package com.github.kklisura.cdt.protocol.commands;

/*-
 * #%L
 * cdt-java-client
 * %%
 * Copyright (C) 2018 - 2019 Kenan Klisura
 * %%
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */

import com.github.kklisura.cdt.protocol.events.page.CompilationCacheProduced;
import com.github.kklisura.cdt.protocol.events.page.DomContentEventFired;
import com.github.kklisura.cdt.protocol.events.page.DownloadWillBegin;
import com.github.kklisura.cdt.protocol.events.page.FileChooserOpened;
import com.github.kklisura.cdt.protocol.events.page.FrameAttached;
import com.github.kklisura.cdt.protocol.events.page.FrameClearedScheduledNavigation;
import com.github.kklisura.cdt.protocol.events.page.FrameDetached;
import com.github.kklisura.cdt.protocol.events.page.FrameNavigated;
import com.github.kklisura.cdt.protocol.events.page.FrameRequestedNavigation;
import com.github.kklisura.cdt.protocol.events.page.FrameResized;
import com.github.kklisura.cdt.protocol.events.page.FrameScheduledNavigation;
import com.github.kklisura.cdt.protocol.events.page.FrameStartedLoading;
import com.github.kklisura.cdt.protocol.events.page.FrameStoppedLoading;
import com.github.kklisura.cdt.protocol.events.page.InterstitialHidden;
import com.github.kklisura.cdt.protocol.events.page.InterstitialShown;
import com.github.kklisura.cdt.protocol.events.page.JavascriptDialogClosed;
import com.github.kklisura.cdt.protocol.events.page.JavascriptDialogOpening;
import com.github.kklisura.cdt.protocol.events.page.LifecycleEvent;
import com.github.kklisura.cdt.protocol.events.page.LoadEventFired;
import com.github.kklisura.cdt.protocol.events.page.NavigatedWithinDocument;
import com.github.kklisura.cdt.protocol.events.page.ScreencastFrame;
import com.github.kklisura.cdt.protocol.events.page.ScreencastVisibilityChanged;
import com.github.kklisura.cdt.protocol.events.page.WindowOpen;
import com.github.kklisura.cdt.protocol.support.annotations.EventName;
import com.github.kklisura.cdt.protocol.support.annotations.Experimental;
import com.github.kklisura.cdt.protocol.support.annotations.Optional;
import com.github.kklisura.cdt.protocol.support.annotations.ParamName;
import com.github.kklisura.cdt.protocol.support.annotations.ReturnTypeParameter;
import com.github.kklisura.cdt.protocol.support.annotations.Returns;
import com.github.kklisura.cdt.protocol.support.types.EventHandler;
import com.github.kklisura.cdt.protocol.support.types.EventListener;
import com.github.kklisura.cdt.protocol.types.debugger.SearchMatch;
import com.github.kklisura.cdt.protocol.types.page.AppManifest;
import com.github.kklisura.cdt.protocol.types.page.CaptureScreenshotFormat;
import com.github.kklisura.cdt.protocol.types.page.CaptureSnapshotFormat;
import com.github.kklisura.cdt.protocol.types.page.FontFamilies;
import com.github.kklisura.cdt.protocol.types.page.FontSizes;
import com.github.kklisura.cdt.protocol.types.page.FrameResourceTree;
import com.github.kklisura.cdt.protocol.types.page.FrameTree;
import com.github.kklisura.cdt.protocol.types.page.HandleFileChooserAction;
import com.github.kklisura.cdt.protocol.types.page.LayoutMetrics;
import com.github.kklisura.cdt.protocol.types.page.Navigate;
import com.github.kklisura.cdt.protocol.types.page.NavigationHistory;
import com.github.kklisura.cdt.protocol.types.page.PrintToPDF;
import com.github.kklisura.cdt.protocol.types.page.PrintToPDFTransferMode;
import com.github.kklisura.cdt.protocol.types.page.ResourceContent;
import com.github.kklisura.cdt.protocol.types.page.SetDownloadBehaviorBehavior;
import com.github.kklisura.cdt.protocol.types.page.SetWebLifecycleStateState;
import com.github.kklisura.cdt.protocol.types.page.StartScreencastFormat;
import com.github.kklisura.cdt.protocol.types.page.TransitionType;
import com.github.kklisura.cdt.protocol.types.page.Viewport;
import java.util.List;

/** Actions and events related to the inspected page belong to the page domain. */
public interface Page {

  /**
   * Deprecated, please use addScriptToEvaluateOnNewDocument instead.
   *
   * @param scriptSource
   */
  @Deprecated
  @Experimental
  @Returns("identifier")
  String addScriptToEvaluateOnLoad(@ParamName("scriptSource") String scriptSource);

  /**
   * Evaluates given script in every frame upon creation (before loading frame's scripts).
   *
   * @param source
   */
  @Returns("identifier")
  String addScriptToEvaluateOnNewDocument(@ParamName("source") String source);

  /**
   * Evaluates given script in every frame upon creation (before loading frame's scripts).
   *
   * @param source
   * @param worldName If specified, creates an isolated world with the given name and evaluates
   *     given script in it. This world name will be used as the ExecutionContextDescription::name
   *     when the corresponding event is emitted.
   */
  @Returns("identifier")
  String addScriptToEvaluateOnNewDocument(
      @ParamName("source") String source,
      @Experimental @Optional @ParamName("worldName") String worldName);

  /** Brings page to front (activates tab). */
  void bringToFront();

  /** Capture page screenshot. */
  @Returns("data")
  String captureScreenshot();

  /**
   * Capture page screenshot.
   *
   * @param format Image compression format (defaults to png).
   * @param quality Compression quality from range [0..100] (jpeg only).
   * @param clip Capture the screenshot of a given region only.
   * @param fromSurface Capture the screenshot from the surface, rather than the view. Defaults to
   *     true.
   */
  @Returns("data")
  String captureScreenshot(
      @Optional @ParamName("format") CaptureScreenshotFormat format,
      @Optional @ParamName("quality") Integer quality,
      @Optional @ParamName("clip") Viewport clip,
      @Experimental @Optional @ParamName("fromSurface") Boolean fromSurface);

  /**
   * Returns a snapshot of the page as a string. For MHTML format, the serialization includes
   * iframes, shadow DOM, external resources, and element-inline styles.
   */
  @Experimental
  @Returns("data")
  String captureSnapshot();

  /**
   * Returns a snapshot of the page as a string. For MHTML format, the serialization includes
   * iframes, shadow DOM, external resources, and element-inline styles.
   *
   * @param format Format (defaults to mhtml).
   */
  @Experimental
  @Returns("data")
  String captureSnapshot(@Optional @ParamName("format") CaptureSnapshotFormat format);

  /**
   * Creates an isolated world for the given frame.
   *
   * @param frameId Id of the frame in which the isolated world should be created.
   */
  @Returns("executionContextId")
  Integer createIsolatedWorld(@ParamName("frameId") String frameId);

  /**
   * Creates an isolated world for the given frame.
   *
   * @param frameId Id of the frame in which the isolated world should be created.
   * @param worldName An optional name which is reported in the Execution Context.
   * @param grantUniveralAccess Whether or not universal access should be granted to the isolated
   *     world. This is a powerful option, use with caution.
   */
  @Returns("executionContextId")
  Integer createIsolatedWorld(
      @ParamName("frameId") String frameId,
      @Optional @ParamName("worldName") String worldName,
      @Optional @ParamName("grantUniveralAccess") Boolean grantUniveralAccess);

  /** Disables page domain notifications. */
  void disable();

  /** Enables page domain notifications. */
  void enable();

  AppManifest getAppManifest();

  @Experimental
  @Returns("errors")
  @ReturnTypeParameter(String.class)
  List getInstallabilityErrors();

  /** Returns present frame tree structure. */
  @Returns("frameTree")
  FrameTree getFrameTree();

  /** Returns metrics relating to the layouting of the page, such as viewport bounds/scale. */
  LayoutMetrics getLayoutMetrics();

  /** Returns navigation history for the current page. */
  NavigationHistory getNavigationHistory();

  /** Resets navigation history for the current page. */
  void resetNavigationHistory();

  /**
   * Returns content of the given resource.
   *
   * @param frameId Frame id to get resource for.
   * @param url URL of the resource to get content for.
   */
  @Experimental
  ResourceContent getResourceContent(
      @ParamName("frameId") String frameId, @ParamName("url") String url);

  /** Returns present frame / resource tree structure. */
  @Experimental
  @Returns("frameTree")
  FrameResourceTree getResourceTree();

  /**
   * Accepts or dismisses a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload).
   *
   * @param accept Whether to accept or dismiss the dialog.
   */
  void handleJavaScriptDialog(@ParamName("accept") Boolean accept);

  /**
   * Accepts or dismisses a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload).
   *
   * @param accept Whether to accept or dismiss the dialog.
   * @param promptText The text to enter into the dialog prompt before accepting. Used only if this
   *     is a prompt dialog.
   */
  void handleJavaScriptDialog(
      @ParamName("accept") Boolean accept, @Optional @ParamName("promptText") String promptText);

  /**
   * Navigates current page to the given URL.
   *
   * @param url URL to navigate the page to.
   */
  Navigate navigate(@ParamName("url") String url);

  /**
   * Navigates current page to the given URL.
   *
   * @param url URL to navigate the page to.
   * @param referrer Referrer URL.
   * @param transitionType Intended transition type.
   * @param frameId Frame id to navigate, if not specified navigates the top frame.
   */
  Navigate navigate(
      @ParamName("url") String url,
      @Optional @ParamName("referrer") String referrer,
      @Optional @ParamName("transitionType") TransitionType transitionType,
      @Optional @ParamName("frameId") String frameId);

  /**
   * Navigates current page to the given history entry.
   *
   * @param entryId Unique id of the entry to navigate to.
   */
  void navigateToHistoryEntry(@ParamName("entryId") Integer entryId);

  /** Print page as PDF. */
  PrintToPDF printToPDF();

  /**
   * Print page as PDF.
   *
   * @param landscape Paper orientation. Defaults to false.
   * @param displayHeaderFooter Display header and footer. Defaults to false.
   * @param printBackground Print background graphics. Defaults to false.
   * @param scale Scale of the webpage rendering. Defaults to 1.
   * @param paperWidth Paper width in inches. Defaults to 8.5 inches.
   * @param paperHeight Paper height in inches. Defaults to 11 inches.
   * @param marginTop Top margin in inches. Defaults to 1cm (~0.4 inches).
   * @param marginBottom Bottom margin in inches. Defaults to 1cm (~0.4 inches).
   * @param marginLeft Left margin in inches. Defaults to 1cm (~0.4 inches).
   * @param marginRight Right margin in inches. Defaults to 1cm (~0.4 inches).
   * @param pageRanges Paper ranges to print, e.g., '1-5, 8, 11-13'. Defaults to the empty string,
   *     which means print all pages.
   * @param ignoreInvalidPageRanges Whether to silently ignore invalid but successfully parsed page
   *     ranges, such as '3-2'. Defaults to false.
   * @param headerTemplate HTML template for the print header. Should be valid HTML markup with
   *     following classes used to inject printing values into them: - `date`: formatted print date
   *     - `title`: document title - `url`: document location - `pageNumber`: current page number -
   *     `totalPages`: total pages in the document
   *     

For example, `` would generate span containing the title. * @param footerTemplate HTML template for the print footer. Should use the same format as the * `headerTemplate`. * @param preferCSSPageSize Whether or not to prefer page size as defined by css. Defaults to * false, in which case the content will be scaled to fit the paper size. * @param transferMode return as stream */ PrintToPDF printToPDF( @Optional @ParamName("landscape") Boolean landscape, @Optional @ParamName("displayHeaderFooter") Boolean displayHeaderFooter, @Optional @ParamName("printBackground") Boolean printBackground, @Optional @ParamName("scale") Double scale, @Optional @ParamName("paperWidth") Double paperWidth, @Optional @ParamName("paperHeight") Double paperHeight, @Optional @ParamName("marginTop") Double marginTop, @Optional @ParamName("marginBottom") Double marginBottom, @Optional @ParamName("marginLeft") Double marginLeft, @Optional @ParamName("marginRight") Double marginRight, @Optional @ParamName("pageRanges") String pageRanges, @Optional @ParamName("ignoreInvalidPageRanges") Boolean ignoreInvalidPageRanges, @Optional @ParamName("headerTemplate") String headerTemplate, @Optional @ParamName("footerTemplate") String footerTemplate, @Optional @ParamName("preferCSSPageSize") Boolean preferCSSPageSize, @Experimental @Optional @ParamName("transferMode") PrintToPDFTransferMode transferMode); /** Reloads given page optionally ignoring the cache. */ void reload(); /** * Reloads given page optionally ignoring the cache. * * @param ignoreCache If true, browser cache is ignored (as if the user pressed Shift+refresh). * @param scriptToEvaluateOnLoad If set, the script will be injected into all frames of the * inspected page after reload. Argument will be ignored if reloading dataURL origin. */ void reload( @Optional @ParamName("ignoreCache") Boolean ignoreCache, @Optional @ParamName("scriptToEvaluateOnLoad") String scriptToEvaluateOnLoad); /** * Deprecated, please use removeScriptToEvaluateOnNewDocument instead. * * @param identifier */ @Deprecated @Experimental void removeScriptToEvaluateOnLoad(@ParamName("identifier") String identifier); /** * Removes given script from the list. * * @param identifier */ void removeScriptToEvaluateOnNewDocument(@ParamName("identifier") String identifier); /** * Acknowledges that a screencast frame has been received by the frontend. * * @param sessionId Frame number. */ @Experimental void screencastFrameAck(@ParamName("sessionId") Integer sessionId); /** * Searches for given string in resource content. * * @param frameId Frame id for resource to search in. * @param url URL of the resource to search in. * @param query String to search for. */ @Experimental @Returns("result") @ReturnTypeParameter(SearchMatch.class) List searchInResource( @ParamName("frameId") String frameId, @ParamName("url") String url, @ParamName("query") String query); /** * Searches for given string in resource content. * * @param frameId Frame id for resource to search in. * @param url URL of the resource to search in. * @param query String to search for. * @param caseSensitive If true, search is case sensitive. * @param isRegex If true, treats string parameter as regex. */ @Experimental @Returns("result") @ReturnTypeParameter(SearchMatch.class) List searchInResource( @ParamName("frameId") String frameId, @ParamName("url") String url, @ParamName("query") String query, @Optional @ParamName("caseSensitive") Boolean caseSensitive, @Optional @ParamName("isRegex") Boolean isRegex); /** * Enable Chrome's experimental ad filter on all sites. * * @param enabled Whether to block ads. */ @Experimental void setAdBlockingEnabled(@ParamName("enabled") Boolean enabled); /** * Enable page Content Security Policy by-passing. * * @param enabled Whether to bypass page CSP. */ @Experimental void setBypassCSP(@ParamName("enabled") Boolean enabled); /** * Set generic font families. * * @param fontFamilies Specifies font families to set. If a font family is not specified, it won't * be changed. */ @Experimental void setFontFamilies(@ParamName("fontFamilies") FontFamilies fontFamilies); /** * Set default font sizes. * * @param fontSizes Specifies font sizes to set. If a font size is not specified, it won't be * changed. */ @Experimental void setFontSizes(@ParamName("fontSizes") FontSizes fontSizes); /** * Sets given markup as the document's HTML. * * @param frameId Frame id to set HTML for. * @param html HTML content to set. */ void setDocumentContent(@ParamName("frameId") String frameId, @ParamName("html") String html); /** * Set the behavior when downloading a file. * * @param behavior Whether to allow all or deny all download requests, or use default Chrome * behavior if available (otherwise deny). */ @Experimental void setDownloadBehavior(@ParamName("behavior") SetDownloadBehaviorBehavior behavior); /** * Set the behavior when downloading a file. * * @param behavior Whether to allow all or deny all download requests, or use default Chrome * behavior if available (otherwise deny). * @param downloadPath The default path to save downloaded files to. This is requred if behavior * is set to 'allow' */ @Experimental void setDownloadBehavior( @ParamName("behavior") SetDownloadBehaviorBehavior behavior, @Optional @ParamName("downloadPath") String downloadPath); /** * Controls whether page will emit lifecycle events. * * @param enabled If true, starts emitting lifecycle events. */ @Experimental void setLifecycleEventsEnabled(@ParamName("enabled") Boolean enabled); /** Starts sending each frame using the `screencastFrame` event. */ @Experimental void startScreencast(); /** * Starts sending each frame using the `screencastFrame` event. * * @param format Image compression format. * @param quality Compression quality from range [0..100]. * @param maxWidth Maximum screenshot width. * @param maxHeight Maximum screenshot height. * @param everyNthFrame Send every n-th frame. */ @Experimental void startScreencast( @Optional @ParamName("format") StartScreencastFormat format, @Optional @ParamName("quality") Integer quality, @Optional @ParamName("maxWidth") Integer maxWidth, @Optional @ParamName("maxHeight") Integer maxHeight, @Optional @ParamName("everyNthFrame") Integer everyNthFrame); /** Force the page stop all navigations and pending resource fetches. */ void stopLoading(); /** Crashes renderer on the IO thread, generates minidumps. */ @Experimental void crash(); /** Tries to close page, running its beforeunload hooks, if any. */ @Experimental void close(); /** * Tries to update the web lifecycle state of the page. It will transition the page to the given * state according to: https://github.com/WICG/web-lifecycle/ * * @param state Target lifecycle state */ @Experimental void setWebLifecycleState(@ParamName("state") SetWebLifecycleStateState state); /** Stops sending each frame in the `screencastFrame`. */ @Experimental void stopScreencast(); /** * Forces compilation cache to be generated for every subresource script. * * @param enabled */ @Experimental void setProduceCompilationCache(@ParamName("enabled") Boolean enabled); /** * Seeds compilation cache for given url. Compilation cache does not survive cross-process * navigation. * * @param url * @param data Base64-encoded data */ @Experimental void addCompilationCache(@ParamName("url") String url, @ParamName("data") String data); /** Clears seeded compilation cache. */ @Experimental void clearCompilationCache(); /** * Generates a report for testing. * * @param message Message to be displayed in the report. */ @Experimental void generateTestReport(@ParamName("message") String message); /** * Generates a report for testing. * * @param message Message to be displayed in the report. * @param group Specifies the endpoint group to deliver the report to. */ @Experimental void generateTestReport( @ParamName("message") String message, @Optional @ParamName("group") String group); /** Pauses page execution. Can be resumed using generic Runtime.runIfWaitingForDebugger. */ @Experimental void waitForDebugger(); /** * Intercept file chooser requests and transfer control to protocol clients. When file chooser * interception is enabled, native file chooser dialog is not shown. Instead, a protocol event * `Page.fileChooserOpened` is emitted. File chooser can be handled with `page.handleFileChooser` * command. * * @param enabled */ @Experimental void setInterceptFileChooserDialog(@ParamName("enabled") Boolean enabled); /** * Accepts or cancels an intercepted file chooser dialog. * * @param action */ @Experimental void handleFileChooser(@ParamName("action") HandleFileChooserAction action); /** * Accepts or cancels an intercepted file chooser dialog. * * @param action * @param files Array of absolute file paths to set, only respected with `accept` action. */ @Experimental void handleFileChooser( @ParamName("action") HandleFileChooserAction action, @Optional @ParamName("files") List files); @EventName("domContentEventFired") EventListener onDomContentEventFired(EventHandler eventListener); /** Emitted only when `page.interceptFileChooser` is enabled. */ @EventName("fileChooserOpened") EventListener onFileChooserOpened(EventHandler eventListener); /** Fired when frame has been attached to its parent. */ @EventName("frameAttached") EventListener onFrameAttached(EventHandler eventListener); /** Fired when frame no longer has a scheduled navigation. */ @EventName("frameClearedScheduledNavigation") @Deprecated EventListener onFrameClearedScheduledNavigation( EventHandler eventListener); /** Fired when frame has been detached from its parent. */ @EventName("frameDetached") EventListener onFrameDetached(EventHandler eventListener); /** * Fired once navigation of the frame has completed. Frame is now associated with the new loader. */ @EventName("frameNavigated") EventListener onFrameNavigated(EventHandler eventListener); @EventName("frameResized") @Experimental EventListener onFrameResized(EventHandler eventListener); /** * Fired when a renderer-initiated navigation is requested. Navigation may still be cancelled * after the event is issued. */ @EventName("frameRequestedNavigation") @Experimental EventListener onFrameRequestedNavigation(EventHandler eventListener); /** Fired when frame schedules a potential navigation. */ @EventName("frameScheduledNavigation") @Deprecated EventListener onFrameScheduledNavigation(EventHandler eventListener); /** Fired when frame has started loading. */ @EventName("frameStartedLoading") @Experimental EventListener onFrameStartedLoading(EventHandler eventListener); /** Fired when frame has stopped loading. */ @EventName("frameStoppedLoading") @Experimental EventListener onFrameStoppedLoading(EventHandler eventListener); /** Fired when page is about to start a download. */ @EventName("downloadWillBegin") @Experimental EventListener onDownloadWillBegin(EventHandler eventListener); /** Fired when interstitial page was hidden */ @EventName("interstitialHidden") EventListener onInterstitialHidden(EventHandler eventListener); /** Fired when interstitial page was shown */ @EventName("interstitialShown") EventListener onInterstitialShown(EventHandler eventListener); /** * Fired when a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload) has been * closed. */ @EventName("javascriptDialogClosed") EventListener onJavascriptDialogClosed(EventHandler eventListener); /** * Fired when a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload) is about * to open. */ @EventName("javascriptDialogOpening") EventListener onJavascriptDialogOpening(EventHandler eventListener); /** Fired for top level page lifecycle events such as navigation, load, paint, etc. */ @EventName("lifecycleEvent") EventListener onLifecycleEvent(EventHandler eventListener); @EventName("loadEventFired") EventListener onLoadEventFired(EventHandler eventListener); /** * Fired when same-document navigation happens, e.g. due to history API usage or anchor * navigation. */ @EventName("navigatedWithinDocument") @Experimental EventListener onNavigatedWithinDocument(EventHandler eventListener); /** Compressed image data requested by the `startScreencast`. */ @EventName("screencastFrame") @Experimental EventListener onScreencastFrame(EventHandler eventListener); /** Fired when the page with currently enabled screencast was shown or hidden `. */ @EventName("screencastVisibilityChanged") @Experimental EventListener onScreencastVisibilityChanged( EventHandler eventListener); /** * Fired when a new window is going to be opened, via window.open(), link click, form submission, * etc. */ @EventName("windowOpen") EventListener onWindowOpen(EventHandler eventListener); /** * Issued for every compilation cache generated. Is only available if * Page.setGenerateCompilationCache is enabled. */ @EventName("compilationCacheProduced") @Experimental EventListener onCompilationCacheProduced(EventHandler eventListener); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy