1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
7 struct PresentationSessionInfo {
12 enum PresentationSessionState {
17 enum PresentationErrorType {
19 SESSION_REQUEST_CANCELLED,
20 NO_PRESENTATION_FOUND,
24 struct PresentationError {
25 PresentationErrorType error_type;
29 enum PresentationMessageType {
35 struct SessionMessage {
36 PresentationMessageType type;
37 // Used when message type is TEXT.
39 // Used when message type is ARRAY_BUFFER or BLOB.
43 interface PresentationService {
44 // Called when the frame sets or changes the default presentation URL.
45 SetDefaultPresentationURL(string url);
47 // Sets the PresentationServiceClient.
48 SetClient(PresentationServiceClient client);
50 // Starts listening for screen availability for the current default
51 // presentation URL. Availability results will be returned to the client
52 // via PresentationServiceClient::OnScreenAvailabilityUpdated.
53 ListenForScreenAvailability();
55 // Stops listening for screen availability for the current default
56 // default presentation URL. The client will stop receiving availability
58 StopListeningForScreenAvailability();
60 // Called when the renderer is ready to receive the browser initiated
61 // session. If the default session is started by the embedder before this
62 // call, the embedder may queue it and run the callback when the call is
64 ListenForDefaultSessionStart()
65 => (PresentationSessionInfo? defaultSessionInfo);
67 // Called when startSession() is called by the frame. The result callback
68 // will return a non-null and valid PresentationSessionInfo if starting the
69 // session succeeded, or null with a PresentationError if starting the
71 // The presentation id returned in |sessionInfo| on success is generated by
73 // If the UA identifies a matching session (same presentation url), the user
74 // may choose this existing session and the page will join it rather than get
76 StartSession(string presentation_url)
77 => (PresentationSessionInfo? sessionInfo, PresentationError? error);
79 // Called when joinSession() is called by the frame. The result callback
80 // works the same as for the method above. JoinSession will join a known
81 // session (i.e. when the page navigates or the user opens another tab)
82 // silently and without user action.
83 JoinSession(string presentation_url, string? presentation_id)
84 => (PresentationSessionInfo? sessionInfo, PresentationError? error);
86 // Called when send() is called by the frame. The true in the
87 // result callback notifies that the service is ready for next message.
88 // The false in the result callback notifies the renderer to stop sending
89 // the send requests and invalidate all pending requests. This occurs
90 // for eg., when frame is deleted or navigated away.
91 SendSessionMessage(PresentationSessionInfo sessionInfo, SessionMessage message_request) => (bool success);
93 // Called when closeSession() is called by the frame.
94 CloseSession(string presentation_url, string presentation_id);
96 // Starts listening for state changes for sessions created on this frame.
97 // When state change occurs, PresentationServiceClient::OnSessionStateChanged
98 // will be invoked with the session and its new state.
99 // This is called after a presentation session is created.
100 ListenForSessionStateChange();
102 // Starts listening for messages for session with |sessionInfo|.
103 // Messages will be received in
104 // PresentationServiceClient::OnSessionMessagesReceived.
105 // This is called after a presentation session is created.
106 ListenForSessionMessages(PresentationSessionInfo sessionInfo);
109 interface PresentationServiceClient {
110 // Called when the client tries to listen for screen availability changes but
111 // it is not supported by the device or underlying platform. This can also be
112 // called if the device is currently in a mode where it can't do screen
113 // discoveries (eg. low battery).
114 OnScreenAvailabilityNotSupported();
116 // Called when the client is listening for screen availability and the state
117 // changes. When the client starts to listen for screen availability, this
118 // method will always be called to give the current known state. It will then
119 // be called to notify of state updates.
120 OnScreenAvailabilityUpdated(bool available);
122 // See PresentationService::ListenForSessionStateChange.
123 OnSessionStateChanged(PresentationSessionInfo sessionInfo,
124 PresentationSessionState newState);
126 // See PresentationService::ListenForSessionMessages.
127 OnSessionMessagesReceived(PresentationSessionInfo sessionInfo, array<SessionMessage> messages);