summaryrefslogtreecommitdiffstats
path: root/netwerk/base/nsIRandomGenerator.idl
blob: 576483b5498f53a3c3948aeb54ff40ee3ca21d13 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsISupports.idl"

%{C++
#include <type_traits>
%}

/**
 * Interface used to generate random data.
 *
 * @threadsafe
 */
[scriptable, uuid(2362d97a-747a-4576-8863-697667309209)]
interface nsIRandomGenerator : nsISupports {
  /**
   * Generates the specified amount of random bytes.
   *
   * @param aLength
   *        The length of the data to generate.
   * @param aBuffer
   *        A buffer that contains random bytes of size aLength.
   */
  void generateRandomBytes(in unsigned long aLength,
                           [retval, array, size_is(aLength)] out octet aBuffer);

  /**
   * Fills aBuffer with random bytes.
   *
   * @param aBuffer
   *        A buffer to fill with random bytes.
   * @param aLength
   *        Length of aBuffer.
   */
  void generateRandomBytesInto([array, size_is(aLength)] in octet aBuffer,
                               in unsigned long aLength);

%{C++
  template<typename T>
  std::enable_if_t<!std::is_pointer_v<T>, nsresult> GenerateRandomBytesInto(T& aResult) {
    return GenerateRandomBytesInto(reinterpret_cast<uint8_t*>(&aResult), sizeof(T));
  }
%}
};