This repository has been archived on 2022-02-10. You can view files and clone it, but cannot push or open issues or pull requests.
fortuna/generator.h
surtur b0eaf5e49e
All checks were successful
continuous-integration/drone/push Build is passing
generator(reseed): concat k with seed, ctr++
also got rid of the redundant ctr variable as we only need the one that
is part of G_state.
2021-11-02 04:40:08 +01:00

30 lines
691 B
C++

#ifndef FORTUNA_GENERATOR_H
#define FORTUNA_GENERATOR_H
#include <string>
#include <cstring>
#include <tuple>
namespace fortuna {
namespace generator {
struct G_state;
/* initializes generator */
G_state *initialize_generator();
auto do_crypto(int64_t k, unsigned __int128 ctr) -> std::string;
auto reseed(G_state G, const std::string& s) -> G_state;
auto do_sha(int64_t key_with_seed) -> int64_t;
auto generate_blocks(G_state G, int k_blocks) -> std::tuple<std::string, G_state>;
/* returns output of 0 <= n <= 2^20 bytes */
auto generate_random_data(G_state G, int n) -> std::tuple<std::string, G_state>;
} //namespace generator
} //namespace fortuna
#endif//FORTUNA_GENERATOR_H