Server : Apache System : Linux iad1-shared-b8-43 6.6.49-grsec-jammy+ #10 SMP Thu Sep 12 23:23:08 UTC 2024 x86_64 User : dh_edsupp ( 6597262) PHP Version : 8.2.26 Disable Function : NONE Directory : /lib/python3/dist-packages/nacl/bindings/ |
Upload File : |
# Copyright 2013 Donald Stufft and individual contributors # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. from nacl import exceptions as exc from nacl._sodium import ffi, lib randombytes_SEEDBYTES: int = lib.randombytes_seedbytes() def randombytes(size: int) -> bytes: """ Returns ``size`` number of random bytes from a cryptographically secure random source. :param size: int :rtype: bytes """ buf = ffi.new("unsigned char[]", size) lib.randombytes(buf, size) return ffi.buffer(buf, size)[:] def randombytes_buf_deterministic(size: int, seed: bytes) -> bytes: """ Returns ``size`` number of deterministically generated pseudorandom bytes from a seed :param size: int :param seed: bytes :rtype: bytes """ if len(seed) != randombytes_SEEDBYTES: raise exc.TypeError( "Deterministic random bytes must be generated from 32 bytes" ) buf = ffi.new("unsigned char[]", size) lib.randombytes_buf_deterministic(buf, size, seed) return ffi.buffer(buf, size)[:]