xref: /aosp_15_r20/external/grpc-grpc/examples/python/cancellation/hash_name.proto (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker// Copyright 2019 the gRPC authors.
2*cc02d7e2SAndroid Build Coastguard Worker//
3*cc02d7e2SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*cc02d7e2SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*cc02d7e2SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*cc02d7e2SAndroid Build Coastguard Worker//
7*cc02d7e2SAndroid Build Coastguard Worker//     http://www.apache.org/licenses/LICENSE-2.0
8*cc02d7e2SAndroid Build Coastguard Worker//
9*cc02d7e2SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*cc02d7e2SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*cc02d7e2SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*cc02d7e2SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*cc02d7e2SAndroid Build Coastguard Worker// limitations under the License.
14*cc02d7e2SAndroid Build Coastguard Worker
15*cc02d7e2SAndroid Build Coastguard Workersyntax = "proto3";
16*cc02d7e2SAndroid Build Coastguard Worker
17*cc02d7e2SAndroid Build Coastguard Workerpackage hash_name;
18*cc02d7e2SAndroid Build Coastguard Worker
19*cc02d7e2SAndroid Build Coastguard Worker// A request for a single secret whose hash is similar to a desired name.
20*cc02d7e2SAndroid Build Coastguard Workermessage HashNameRequest {
21*cc02d7e2SAndroid Build Coastguard Worker  // The string that is desired in the secret's hash.
22*cc02d7e2SAndroid Build Coastguard Worker  string desired_name = 1;
23*cc02d7e2SAndroid Build Coastguard Worker
24*cc02d7e2SAndroid Build Coastguard Worker  // The ideal Hamming distance between desired_name and the secret that will
25*cc02d7e2SAndroid Build Coastguard Worker  // be searched for.
26*cc02d7e2SAndroid Build Coastguard Worker  int32 ideal_hamming_distance = 2;
27*cc02d7e2SAndroid Build Coastguard Worker
28*cc02d7e2SAndroid Build Coastguard Worker  // A Hamming distance greater than the ideal Hamming distance. Search results
29*cc02d7e2SAndroid Build Coastguard Worker  // with a Hamming distance less than this value but greater than the ideal
30*cc02d7e2SAndroid Build Coastguard Worker  // distance will be returned back to the client but will not terminate the
31*cc02d7e2SAndroid Build Coastguard Worker  // search.
32*cc02d7e2SAndroid Build Coastguard Worker  int32 interesting_hamming_distance = 3;
33*cc02d7e2SAndroid Build Coastguard Worker}
34*cc02d7e2SAndroid Build Coastguard Worker
35*cc02d7e2SAndroid Build Coastguard Workermessage HashNameResponse {
36*cc02d7e2SAndroid Build Coastguard Worker  // The search result.
37*cc02d7e2SAndroid Build Coastguard Worker  string secret = 1;
38*cc02d7e2SAndroid Build Coastguard Worker
39*cc02d7e2SAndroid Build Coastguard Worker  // The hash of the search result. A substring of this is of
40*cc02d7e2SAndroid Build Coastguard Worker  // ideal_hamming_distance Hamming distance or less from desired_name.
41*cc02d7e2SAndroid Build Coastguard Worker  string hashed_name = 2;
42*cc02d7e2SAndroid Build Coastguard Worker
43*cc02d7e2SAndroid Build Coastguard Worker  // The Hamming distance between hashed_name and desired_name.
44*cc02d7e2SAndroid Build Coastguard Worker  int32 hamming_distance = 3;
45*cc02d7e2SAndroid Build Coastguard Worker}
46*cc02d7e2SAndroid Build Coastguard Worker
47*cc02d7e2SAndroid Build Coastguard Workerservice HashFinder {
48*cc02d7e2SAndroid Build Coastguard Worker
49*cc02d7e2SAndroid Build Coastguard Worker  // Search for a single string whose hash is similar to the specified
50*cc02d7e2SAndroid Build Coastguard Worker  // desired_name. interesting_hamming_distance is ignored.
51*cc02d7e2SAndroid Build Coastguard Worker  rpc Find (HashNameRequest) returns (HashNameResponse) {}
52*cc02d7e2SAndroid Build Coastguard Worker
53*cc02d7e2SAndroid Build Coastguard Worker  // Search for a string whose hash is similar to the specified desired_name,
54*cc02d7e2SAndroid Build Coastguard Worker  // but also stream back less-than-ideal candidates.
55*cc02d7e2SAndroid Build Coastguard Worker  rpc FindRange (HashNameRequest) returns (stream HashNameResponse) {}
56*cc02d7e2SAndroid Build Coastguard Worker}
57