xref: /aosp_15_r20/external/federated-compute/fcp/secagg/shared/prng.h (revision 14675a029014e728ec732f129a32e299b2da0601)
1*14675a02SAndroid Build Coastguard Worker /*
2*14675a02SAndroid Build Coastguard Worker  * Copyright 2018 Google LLC
3*14675a02SAndroid Build Coastguard Worker  *
4*14675a02SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*14675a02SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*14675a02SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*14675a02SAndroid Build Coastguard Worker  *
8*14675a02SAndroid Build Coastguard Worker  *     https://www.apache.org/licenses/LICENSE-2.0
9*14675a02SAndroid Build Coastguard Worker  *
10*14675a02SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*14675a02SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*14675a02SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*14675a02SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*14675a02SAndroid Build Coastguard Worker  * limitations under the License.
15*14675a02SAndroid Build Coastguard Worker  */
16*14675a02SAndroid Build Coastguard Worker 
17*14675a02SAndroid Build Coastguard Worker #ifndef FCP_SECAGG_SHARED_PRNG_H_
18*14675a02SAndroid Build Coastguard Worker #define FCP_SECAGG_SHARED_PRNG_H_
19*14675a02SAndroid Build Coastguard Worker 
20*14675a02SAndroid Build Coastguard Worker #include <cstdint>
21*14675a02SAndroid Build Coastguard Worker #include <vector>
22*14675a02SAndroid Build Coastguard Worker 
23*14675a02SAndroid Build Coastguard Worker namespace fcp {
24*14675a02SAndroid Build Coastguard Worker namespace secagg {
25*14675a02SAndroid Build Coastguard Worker 
26*14675a02SAndroid Build Coastguard Worker // An interface for a secure pseudo-random number generator.
27*14675a02SAndroid Build Coastguard Worker class SecurePrng {
28*14675a02SAndroid Build Coastguard Worker  public:
29*14675a02SAndroid Build Coastguard Worker   virtual uint8_t Rand8() = 0;
30*14675a02SAndroid Build Coastguard Worker   virtual uint64_t Rand64() = 0;
31*14675a02SAndroid Build Coastguard Worker   virtual ~SecurePrng() = default;
32*14675a02SAndroid Build Coastguard Worker };
33*14675a02SAndroid Build Coastguard Worker 
34*14675a02SAndroid Build Coastguard Worker // Extension of SecurePrng interface that supports batch mode - getting multiple
35*14675a02SAndroid Build Coastguard Worker // pseudo-random numbers in a single call.
36*14675a02SAndroid Build Coastguard Worker class SecureBatchPrng : public SecurePrng {
37*14675a02SAndroid Build Coastguard Worker  public:
38*14675a02SAndroid Build Coastguard Worker   // Get the maximum size of a buffer that can be filled by RandBuffer() in a
39*14675a02SAndroid Build Coastguard Worker   // single call.
40*14675a02SAndroid Build Coastguard Worker   virtual size_t GetMaxBufferSize() const = 0;
41*14675a02SAndroid Build Coastguard Worker 
42*14675a02SAndroid Build Coastguard Worker   // Fills the provided buffer with pseudorandom bytes. Returns the number of
43*14675a02SAndroid Build Coastguard Worker   // bytes that has been generated, which can be smaller than the requested
44*14675a02SAndroid Build Coastguard Worker   // buffer_size if it exceeds the maximum buffer size.
45*14675a02SAndroid Build Coastguard Worker   virtual int RandBuffer(uint8_t* buffer, int buffer_size) = 0;
46*14675a02SAndroid Build Coastguard Worker };
47*14675a02SAndroid Build Coastguard Worker 
48*14675a02SAndroid Build Coastguard Worker }  // namespace secagg
49*14675a02SAndroid Build Coastguard Worker }  // namespace fcp
50*14675a02SAndroid Build Coastguard Worker 
51*14675a02SAndroid Build Coastguard Worker #endif  // FCP_SECAGG_SHARED_PRNG_H_
52