chromium/media/mojo/mojom/cdm_storage.mojom

// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

module media.mojom;

// Provides a way to organize persistent per-origin/per-cdm-type data
// in the browser's file system.
interface CdmStorage {
  // These values are persisted to logs. Entries should not be renumbered and
  // numeric values should never be reused.
  enum Status {
    kSuccess = 0,  // File was successfully opened.
    kInUse = 1,    // File is already open by another client.
    kFailure = 2   // Unable to open file.
  };

  // Opens the file specified by |file_name|. Can be called multiple times for
  // different files, or for the same file if the first one has been closed.
  // If successful, kSuccess will be returned, and |cdm_file| should be used to
  // access the file. |cdm_file| should be closed when access to the file is no
  // longer needed. On failure, |status| <> kSuccess and |cdm_file| is null.
  // - If the file is already opened, kInUse will be returned in |status|.
  // - |file_name| must not contain forward slash ('/') or backslash ('\'),
  //   and must not start with an underscore ('_'). If this happens,
  //   |status| == kFailure is returned.
  Open(string file_name)
    => (Status status, pending_associated_remote<CdmFile>? cdm_file);
};

// Provides a way to access the contents of the file opened. When the connection
// to this object is broken, it is assumed that the file has been closed and
// that no more operations will be performed on it. Only 1 Read() or Write()
// operation should be in flight at any time.
interface CdmFile {
  enum Status {
    kSuccess,  // Operation succeeded.
    kFailure   // Operation failed.
  };

  // Reads the contents of the file and return them in |data|. Returns
  // kSuccess and the file contents if successful. Errors reading the file will
  // return kFailure. If the opened file does not exist, Read() will return
  // kSuccess and |data| will be the empty array.
  Read() => (Status status, array<uint8> data);

  // Updates the contents of the existing file with |data|. If the
  // write operation is successful, then kSuccess is returned, otherwise
  // kFailure is returned. If |data| is empty, then the file is deleted to
  // save space. The contents of the file are unknown if Write()
  // fails.
  Write(array<uint8> data) => (Status status);
};