xref: /aosp_15_r20/external/googleapis/google/cloud/discoveryengine/v1beta/conversation.proto (revision d5c09012810ac0c9f33fe448fb6da8260d444cc9)
1*d5c09012SAndroid Build Coastguard Worker// Copyright 2022 Google LLC
2*d5c09012SAndroid Build Coastguard Worker//
3*d5c09012SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*d5c09012SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*d5c09012SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*d5c09012SAndroid Build Coastguard Worker//
7*d5c09012SAndroid Build Coastguard Worker//     http://www.apache.org/licenses/LICENSE-2.0
8*d5c09012SAndroid Build Coastguard Worker//
9*d5c09012SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*d5c09012SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*d5c09012SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*d5c09012SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*d5c09012SAndroid Build Coastguard Worker// limitations under the License.
14*d5c09012SAndroid Build Coastguard Worker
15*d5c09012SAndroid Build Coastguard Workersyntax = "proto3";
16*d5c09012SAndroid Build Coastguard Worker
17*d5c09012SAndroid Build Coastguard Workerpackage google.cloud.discoveryengine.v1beta;
18*d5c09012SAndroid Build Coastguard Worker
19*d5c09012SAndroid Build Coastguard Workerimport "google/api/field_behavior.proto";
20*d5c09012SAndroid Build Coastguard Workerimport "google/api/resource.proto";
21*d5c09012SAndroid Build Coastguard Workerimport "google/cloud/discoveryengine/v1beta/search_service.proto";
22*d5c09012SAndroid Build Coastguard Workerimport "google/protobuf/timestamp.proto";
23*d5c09012SAndroid Build Coastguard Worker
24*d5c09012SAndroid Build Coastguard Workeroption csharp_namespace = "Google.Cloud.DiscoveryEngine.V1Beta";
25*d5c09012SAndroid Build Coastguard Workeroption go_package = "cloud.google.com/go/discoveryengine/apiv1beta/discoveryenginepb;discoveryenginepb";
26*d5c09012SAndroid Build Coastguard Workeroption java_multiple_files = true;
27*d5c09012SAndroid Build Coastguard Workeroption java_outer_classname = "ConversationProto";
28*d5c09012SAndroid Build Coastguard Workeroption java_package = "com.google.cloud.discoveryengine.v1beta";
29*d5c09012SAndroid Build Coastguard Workeroption objc_class_prefix = "DISCOVERYENGINE";
30*d5c09012SAndroid Build Coastguard Workeroption php_namespace = "Google\\Cloud\\DiscoveryEngine\\V1beta";
31*d5c09012SAndroid Build Coastguard Workeroption ruby_package = "Google::Cloud::DiscoveryEngine::V1beta";
32*d5c09012SAndroid Build Coastguard Worker
33*d5c09012SAndroid Build Coastguard Worker// External conversation proto definition.
34*d5c09012SAndroid Build Coastguard Workermessage Conversation {
35*d5c09012SAndroid Build Coastguard Worker  option (google.api.resource) = {
36*d5c09012SAndroid Build Coastguard Worker    type: "discoveryengine.googleapis.com/Conversation"
37*d5c09012SAndroid Build Coastguard Worker    pattern: "projects/{project}/locations/{location}/dataStores/{data_store}/conversations/{conversation}"
38*d5c09012SAndroid Build Coastguard Worker    pattern: "projects/{project}/locations/{location}/collections/{collection}/dataStores/{data_store}/conversations/{conversation}"
39*d5c09012SAndroid Build Coastguard Worker    pattern: "projects/{project}/locations/{location}/collections/{collection}/engines/{engine}/conversations/{conversation}"
40*d5c09012SAndroid Build Coastguard Worker  };
41*d5c09012SAndroid Build Coastguard Worker
42*d5c09012SAndroid Build Coastguard Worker  // Enumeration of the state of the conversation.
43*d5c09012SAndroid Build Coastguard Worker  enum State {
44*d5c09012SAndroid Build Coastguard Worker    // Unknown.
45*d5c09012SAndroid Build Coastguard Worker    STATE_UNSPECIFIED = 0;
46*d5c09012SAndroid Build Coastguard Worker
47*d5c09012SAndroid Build Coastguard Worker    // Conversation is currently open.
48*d5c09012SAndroid Build Coastguard Worker    IN_PROGRESS = 1;
49*d5c09012SAndroid Build Coastguard Worker
50*d5c09012SAndroid Build Coastguard Worker    // Conversation has been completed.
51*d5c09012SAndroid Build Coastguard Worker    COMPLETED = 2;
52*d5c09012SAndroid Build Coastguard Worker  }
53*d5c09012SAndroid Build Coastguard Worker
54*d5c09012SAndroid Build Coastguard Worker  // Immutable. Fully qualified name
55*d5c09012SAndroid Build Coastguard Worker  // `project/*/locations/global/collections/{collection}/dataStore/*/conversations/*`
56*d5c09012SAndroid Build Coastguard Worker  // or
57*d5c09012SAndroid Build Coastguard Worker  // `project/*/locations/global/collections/{collection}/engines/*/conversations/*`.
58*d5c09012SAndroid Build Coastguard Worker  string name = 1 [(google.api.field_behavior) = IMMUTABLE];
59*d5c09012SAndroid Build Coastguard Worker
60*d5c09012SAndroid Build Coastguard Worker  // The state of the Conversation.
61*d5c09012SAndroid Build Coastguard Worker  State state = 2;
62*d5c09012SAndroid Build Coastguard Worker
63*d5c09012SAndroid Build Coastguard Worker  // A unique identifier for tracking users.
64*d5c09012SAndroid Build Coastguard Worker  string user_pseudo_id = 3;
65*d5c09012SAndroid Build Coastguard Worker
66*d5c09012SAndroid Build Coastguard Worker  // Conversation messages.
67*d5c09012SAndroid Build Coastguard Worker  repeated ConversationMessage messages = 4;
68*d5c09012SAndroid Build Coastguard Worker
69*d5c09012SAndroid Build Coastguard Worker  // Output only. The time the conversation started.
70*d5c09012SAndroid Build Coastguard Worker  google.protobuf.Timestamp start_time = 5
71*d5c09012SAndroid Build Coastguard Worker      [(google.api.field_behavior) = OUTPUT_ONLY];
72*d5c09012SAndroid Build Coastguard Worker
73*d5c09012SAndroid Build Coastguard Worker  // Output only. The time the conversation finished.
74*d5c09012SAndroid Build Coastguard Worker  google.protobuf.Timestamp end_time = 6
75*d5c09012SAndroid Build Coastguard Worker      [(google.api.field_behavior) = OUTPUT_ONLY];
76*d5c09012SAndroid Build Coastguard Worker}
77*d5c09012SAndroid Build Coastguard Worker
78*d5c09012SAndroid Build Coastguard Worker// Defines a reply message to user.
79*d5c09012SAndroid Build Coastguard Workermessage Reply {
80*d5c09012SAndroid Build Coastguard Worker  // Defines reference in reply.
81*d5c09012SAndroid Build Coastguard Worker  message Reference {
82*d5c09012SAndroid Build Coastguard Worker    option deprecated = true;
83*d5c09012SAndroid Build Coastguard Worker
84*d5c09012SAndroid Build Coastguard Worker    // URI link reference.
85*d5c09012SAndroid Build Coastguard Worker    string uri = 1;
86*d5c09012SAndroid Build Coastguard Worker
87*d5c09012SAndroid Build Coastguard Worker    // Anchor text.
88*d5c09012SAndroid Build Coastguard Worker    string anchor_text = 2;
89*d5c09012SAndroid Build Coastguard Worker
90*d5c09012SAndroid Build Coastguard Worker    // Anchor text start index.
91*d5c09012SAndroid Build Coastguard Worker    int32 start = 3;
92*d5c09012SAndroid Build Coastguard Worker
93*d5c09012SAndroid Build Coastguard Worker    // Anchor text end index.
94*d5c09012SAndroid Build Coastguard Worker    int32 end = 4;
95*d5c09012SAndroid Build Coastguard Worker  }
96*d5c09012SAndroid Build Coastguard Worker
97*d5c09012SAndroid Build Coastguard Worker  // DEPRECATED: use `summary` instead.
98*d5c09012SAndroid Build Coastguard Worker  // Text reply.
99*d5c09012SAndroid Build Coastguard Worker  string reply = 1 [deprecated = true];
100*d5c09012SAndroid Build Coastguard Worker
101*d5c09012SAndroid Build Coastguard Worker  // References in the reply.
102*d5c09012SAndroid Build Coastguard Worker  repeated Reference references = 2 [deprecated = true];
103*d5c09012SAndroid Build Coastguard Worker
104*d5c09012SAndroid Build Coastguard Worker  // Summary based on search results.
105*d5c09012SAndroid Build Coastguard Worker  SearchResponse.Summary summary = 3;
106*d5c09012SAndroid Build Coastguard Worker}
107*d5c09012SAndroid Build Coastguard Worker
108*d5c09012SAndroid Build Coastguard Worker// Defines context of the conversation
109*d5c09012SAndroid Build Coastguard Workermessage ConversationContext {
110*d5c09012SAndroid Build Coastguard Worker  // The current list of documents the user is seeing.
111*d5c09012SAndroid Build Coastguard Worker  // It contains the document resource references.
112*d5c09012SAndroid Build Coastguard Worker  repeated string context_documents = 1;
113*d5c09012SAndroid Build Coastguard Worker
114*d5c09012SAndroid Build Coastguard Worker  // The current active document the user opened.
115*d5c09012SAndroid Build Coastguard Worker  // It contains the document resource reference.
116*d5c09012SAndroid Build Coastguard Worker  string active_document = 2;
117*d5c09012SAndroid Build Coastguard Worker}
118*d5c09012SAndroid Build Coastguard Worker
119*d5c09012SAndroid Build Coastguard Worker// Defines text input.
120*d5c09012SAndroid Build Coastguard Workermessage TextInput {
121*d5c09012SAndroid Build Coastguard Worker  // Text input.
122*d5c09012SAndroid Build Coastguard Worker  string input = 1;
123*d5c09012SAndroid Build Coastguard Worker
124*d5c09012SAndroid Build Coastguard Worker  // Conversation context of the input.
125*d5c09012SAndroid Build Coastguard Worker  ConversationContext context = 2;
126*d5c09012SAndroid Build Coastguard Worker}
127*d5c09012SAndroid Build Coastguard Worker
128*d5c09012SAndroid Build Coastguard Worker// Defines a conversation message.
129*d5c09012SAndroid Build Coastguard Workermessage ConversationMessage {
130*d5c09012SAndroid Build Coastguard Worker  oneof message {
131*d5c09012SAndroid Build Coastguard Worker    // User text input.
132*d5c09012SAndroid Build Coastguard Worker    TextInput user_input = 1;
133*d5c09012SAndroid Build Coastguard Worker
134*d5c09012SAndroid Build Coastguard Worker    // Search reply.
135*d5c09012SAndroid Build Coastguard Worker    Reply reply = 2;
136*d5c09012SAndroid Build Coastguard Worker  }
137*d5c09012SAndroid Build Coastguard Worker
138*d5c09012SAndroid Build Coastguard Worker  // Output only. Message creation timestamp.
139*d5c09012SAndroid Build Coastguard Worker  google.protobuf.Timestamp create_time = 3
140*d5c09012SAndroid Build Coastguard Worker      [(google.api.field_behavior) = OUTPUT_ONLY];
141*d5c09012SAndroid Build Coastguard Worker}
142