910e62b5创建于 1月15日历史提交
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// Use the <code>chrome.pdfViewerPrivate</code> API for specific browser
// functionality that the PDF Viewer needs from outside the PDF plugin. This API
// is exclusively for the PDF Viewer.
namespace pdfViewerPrivate {
  // Must match `SaveRequestType` in `pdf/mojom/pdf.mojom` and
  // `tools/typescript/definitions/pdf_viewer_private.d.ts`.
  enum SaveRequestType {
    ANNOTATION,
    ORIGINAL,
    EDITED,
    SEARCHIFIED
  };

  // Enumeration of save to drive error types. Must match `SaveToDriveErrorType`
  // in tools/typescript/definitions/pdf_viewer_private.d.ts and
  // `PdfSaveToDriveErrorType` in
  // tools/metrics/histograms/metadata/pdf/enums.xml.
  enum SaveToDriveErrorType {
    NO_ERROR,
    UNKNOWN_ERROR,
    QUOTA_EXCEEDED,
    OFFLINE,
    OAUTH_ERROR,
    ACCOUNT_CHOOSER_CANCELED,
    PARENT_FOLDER_SELECTION_FAILED
  };

  // Enumeration of save to drive status. Must match `SaveToDriveStatus` in
  // tools/typescript/definitions/pdf_viewer_private.d.ts and
  // `PdfSaveToDriveStatus` in
  // tools/metrics/histograms/metadata/pdf/enums.xml.
  enum SaveToDriveStatus {
    NOT_STARTED,
    INITIATED,
    ACCOUNT_CHOOSER_SHOWN,
    ACCOUNT_SELECTED,
    ACCOUNT_ADD_SELECTED,
    ACCOUNT_ADDED,
    FETCH_OAUTH,
    FETCH_PARENT_FOLDER,
    UPLOAD_STARTED,
    UPLOAD_IN_PROGRESS,
    UPLOAD_COMPLETED,
    UPLOAD_RETRIED,
    UPLOAD_FAILED
  };

  // Progress of a save to drive request.
  dictionary SaveToDriveProgress {
    // The status of the upload.
    SaveToDriveStatus status;

    // The error type of the upload.
    SaveToDriveErrorType errorType;

    // The ID of the drive item that was uploaded. It is only set if the upload
    // was successful, i.e. if `status` is `UPLOAD_COMPLETED`.
    DOMString? driveItemId;

    // The total size of the file in bytes. It is only set if the upload is in
    // progress or completed, i.e. if `status` is `UPLOAD_STARTED`,
    // `UPLOAD_IN_PROGRESS`, or `UPLOAD_COMPLETED`.
    long? fileSizeBytes;

    // The number of bytes that have been uploaded. It is only set if the upload
    // is in progress or completed, i.e. if `status` is `UPLOAD_STARTED`,
    // `UPLOAD_IN_PROGRESS`, or `UPLOAD_COMPLETED`.
    long? uploadedBytes;

    // The localized metadata and progress of the file. It is only set if the
    // upload is in progress or completed, i.e. if `status` is `UPLOAD_STARTED`,
    // `UPLOAD_IN_PROGRESS`, or `UPLOAD_COMPLETED`.
    DOMString? fileMetadata;

    // The name of the file. It is only set if the upload was successful, i.e.
    // if `status` is `UPLOAD_COMPLETED`.
    DOMString? fileName;

    // The name of the parent folder. It is only set if the upload was
    // successful, i.e. if `status` is `UPLOAD_COMPLETED`.
    DOMString? parentFolderName;

    // The email of the account that is chosen to save the PDF to Drive. It is
    // only set after the account is selected.
    DOMString? accountEmail;

    // Whether the account is a managed account. It is only set after the
    // account is selected.
    boolean? accountIsManaged;
  };

  // Nearly identical to mimeHandlerPrivate.StreamInfo, but without a mime type
  // nor a response header field. Those fields are unused by the PDF viewer.
  dictionary StreamInfo {
    // The original URL that was intercepted.
    DOMString originalUrl;

    // The URL that the stream can be read from.
    DOMString streamUrl;

    // The ID of the tab that opened the stream. If the stream is not opened in
    // a tab, it will be -1.
    long tabId;

    // Whether the stream is embedded within another document.
    boolean embedded;
  };

  // Identical to mimeHandlerPrivate.StreamInfo.
  dictionary PdfPluginAttributes {
    // The background color in ARGB format for painting. Since the background
    // color is an unsigned 32-bit integer which can be outside the range of
    // "long" type, define it as a "double" type here.
    double backgroundColor;

    // Indicates whether the plugin allows to execute JavaScript and maybe XFA.
    // Loading XFA for PDF forms will automatically be disabled if this flag is
    // false.
    boolean allowJavascript;
  };

  callback GetStreamInfoCallback = void(StreamInfo streamInfo);
  callback IsAllowedLocalFileAccessCallback = void(boolean result);
  callback VoidCallback = void();

  interface Functions {
    // Returns the StreamInfo for the stream for this context if there is one.
    static void getStreamInfo(
        GetStreamInfoCallback callback);

    // Determines if the given URL should be allowed to access local files from
    // the PDF Viewer. |callback|: Called with true if URL should be allowed to
    // access local files from the PDF Viewer, false otherwise.
    static void isAllowedLocalFileAccess(
        DOMString url,
        IsAllowedLocalFileAccessCallback callback);

    // Sends a request to save the PDF to Google Drive if `saveRequestType` is
    // set. Otherwise, if `saveRequestType` is not set, the default action is
    // to cancel the existing upload.
    static void saveToDrive(
        optional SaveRequestType saveRequestType,
        optional VoidCallback callback);

    // Sets the current tab title to `title` for a full-page PDF.
    static void setPdfDocumentTitle(
        DOMString title,
        optional VoidCallback callback);

    // Sets PDF plugin attributes in the stream for this context if there is
    // one.
    static void setPdfPluginAttributes(
        PdfPluginAttributes attributes,
        optional VoidCallback callback);
  };

  interface Events {
    // Fired when the browser wants the listener to perform a save.
    // `streamUrl`: Unique ID for the instance that should perform the save.
    static void onSave(DOMString streamUrl);

    // Fired when the browser wants the listener to update the save to drive
    // progress.
    // `streamUrl`: Unique ID for the instance that should perform the save.
    // `progress`: The progress of the save to drive.
    static void onSaveToDriveProgress(DOMString streamUrl,
                                      SaveToDriveProgress progress);

    // Fired when the browser wants the listener to update the viewport based on
    // a different PDF URL.
    // `pdfUrl`: The string of the PDF URL that should update the viewport.
    static void onShouldUpdateViewport(DOMString pdfUrl);
  };
};