chromium/components/services/storage/privileged/mojom/bucket_client_info.mojom

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

module storage.mojom;

import "third_party/blink/public/mojom/tokens/tokens.mojom";

// Information about the browser process representation of an execution context
// (frame or worker) acting as the client of a bucket.
//
// Typemapping is maintained between this and storage::BucketClientInfo.
struct BucketClientInfo {
  // The ID of the `RenderProcessHost` that the client belongs to.
  int32 process_id;

  // A token that uniquely identifies the client's execution context.
  // Expected to only be a `LocalFrameToken`, `DedicatedWorkerToken`,
  // `ServiceWorkerToken`, or `SharedWorkerToken`.
  // This expectation is asserted in bucket_client_info_mojom_traits.cc.
  blink.mojom.ExecutionContextToken context_token;

  // The token of the document associated with the client, if there is one.
  // Expected to be set only if `context_token` is a `LocalFrameToken` or a
  // `DedicatedWorkerToken`.
  // This expectation is asserted in bucket_client_info_mojom_traits.cc.
  blink.mojom.DocumentToken? document_token;
};