chromium/ash/components/arc/mojom/nearby_share.mojom

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

module arc.mojom;

import "url/mojom/url.mojom";

// This mojo file defines the interface that Android apps on ChromeOS will use
// to allow users to share data (text/files) to nearby share targets, using
// ChromeOS's NearbyShare view. Nearby share is the ability for a user to share
// data from a ChromeOS device to another ChromeOS or Android device.

// Represents details about a shared file.
struct FileInfo {
  url.mojom.Url content_uri;  // Content URI for the shared file
  string mime_type;           // MIME type for the file
  string name;                // File name
  int64 size;                 // Match Long type in ARC for file size in bytes
};

// Represents the share information received from an Android app.
struct ShareIntentInfo {
  string title;                 // Title of share intent
  string mime_type;             // MIME type for the data.
                                // (e.g. text/*, text/plain, image/*, etc)
  map<string, string>? extras;  // (optional) Metadata from the Android intent
  array<FileInfo>? files;       // (optional) Shared file information
};

// Represents the Chrome side of NearbyShare session. Used by ARC to send
// NearbyShare messages to Chrome and interact with the ARC Window used
// for NearbyShare.
// Closing the interface will close the ARC Window.
// Next method ID: 0
interface NearbyShareSessionHost {
};

// Represents the ARC side of a NearbyShare session. Used by Chrome to send
// share-related messages to ARC.
// Next method ID: 1
interface NearbyShareSessionInstance {
  // Called when Chrome NearbyShare view is closed.
  OnNearbyShareViewClosed@0();
};

// Interface for Android to communicate with Chrome.
// Next method ID: 1
interface NearbyShareHost {
  // Used to create a NearbyShare session.
  StartNearbyShare@0(
      uint32 task_id,
      ShareIntentInfo info,
      pending_remote<NearbyShareSessionInstance> instance)
      => (pending_remote<NearbyShareSessionHost> host);
};

// Interface for Chrome to communicate with Android.
// Next method ID: 1
interface NearbyShareInstance {
  // Establishes full-duplex communication with the host.
  Init@0(pending_remote<NearbyShareHost> host_remote) => ();
};