/**
 * This code was generated by [react-native-codegen](https://www.npmjs.com/package/react-native-codegen).
 *
 * Do not edit this file as changes may cause incorrect behavior and will be lost
 * once the code is regenerated.
 *
 * @generated by codegen project: GenerateModuleH.js
 */

#pragma once

#include <ReactCommon/TurboModule.h>
#include <react/bridging/Bridging.h>

namespace facebook::react {


  
#pragma mark - NativeEncryptionkeypair

template <typename P0, typename P1>
struct NativeEncryptionkeypair {
  P0 publicKey;
  P1 privateKey;
  bool operator==(const NativeEncryptionkeypair &other) const {
    return publicKey == other.publicKey && privateKey == other.privateKey;
  }
};

template <typename T>
struct NativeEncryptionkeypairBridging {
  static T types;

  static T fromJs(
      jsi::Runtime &rt,
      const jsi::Object &value,
      const std::shared_ptr<CallInvoker> &jsInvoker) {
    T result{
      bridging::fromJs<decltype(types.publicKey)>(rt, value.getProperty(rt, "publicKey"), jsInvoker),
      bridging::fromJs<decltype(types.privateKey)>(rt, value.getProperty(rt, "privateKey"), jsInvoker)};
    return result;
  }

#ifdef DEBUG
  static jsi::String publicKeyToJs(jsi::Runtime &rt, decltype(types.publicKey) value) {
    return bridging::toJs(rt, value);
  }

  static jsi::String privateKeyToJs(jsi::Runtime &rt, decltype(types.privateKey) value) {
    return bridging::toJs(rt, value);
  }
#endif

  static jsi::Object toJs(
      jsi::Runtime &rt,
      const T &value,
      const std::shared_ptr<CallInvoker> &jsInvoker) {
    auto result = facebook::jsi::Object(rt);
    result.setProperty(rt, "publicKey", bridging::toJs(rt, value.publicKey, jsInvoker));
    result.setProperty(rt, "privateKey", bridging::toJs(rt, value.privateKey, jsInvoker));
    return result;
  }
};

class JSI_EXPORT NativeEncryptionCxxSpecJSI : public TurboModule {
protected:
  NativeEncryptionCxxSpecJSI(std::shared_ptr<CallInvoker> jsInvoker);

public:
  virtual jsi::String generateAESKey(jsi::Runtime &rt, double keySize) = 0;
  virtual jsi::String encryptAES(jsi::Runtime &rt, jsi::String data, jsi::String key) = 0;
  virtual jsi::String decryptAES(jsi::Runtime &rt, jsi::String data, jsi::String key) = 0;
  virtual jsi::Value encryptFile(jsi::Runtime &rt, jsi::String inputPath, jsi::String outputPath, jsi::String key) = 0;
  virtual jsi::Value decryptFile(jsi::Runtime &rt, jsi::String inputPath, jsi::String key) = 0;
  virtual jsi::Value encryptAsyncAES(jsi::Runtime &rt, jsi::String data, jsi::String key) = 0;
  virtual jsi::Value decryptAsyncAES(jsi::Runtime &rt, jsi::String data, jsi::String key) = 0;
  virtual jsi::Object generateRSAKeyPair(jsi::Runtime &rt) = 0;
  virtual jsi::String getPublicRSAkey(jsi::Runtime &rt, jsi::String privateRSAkey) = 0;
  virtual jsi::String encryptRSA(jsi::Runtime &rt, jsi::String data, jsi::String publicKey) = 0;
  virtual jsi::String decryptRSA(jsi::Runtime &rt, jsi::String data, jsi::String privateKey) = 0;
  virtual jsi::Value encryptAsyncRSA(jsi::Runtime &rt, jsi::String data, jsi::String publicKey) = 0;
  virtual jsi::Value decryptAsyncRSA(jsi::Runtime &rt, jsi::String data, jsi::String privateKey) = 0;
  virtual jsi::String hashSHA256(jsi::Runtime &rt, jsi::String input) = 0;
  virtual jsi::String hashSHA512(jsi::Runtime &rt, jsi::String input) = 0;
  virtual jsi::String generateHMACKey(jsi::Runtime &rt, double keySize) = 0;
  virtual jsi::String hmacSHA256(jsi::Runtime &rt, jsi::String data, jsi::String key) = 0;
  virtual jsi::String hmacSHA512(jsi::Runtime &rt, jsi::String data, jsi::String key) = 0;
  virtual jsi::String generateRandomString(jsi::Runtime &rt, double input) = 0;
  virtual jsi::String base64Encode(jsi::Runtime &rt, jsi::String input) = 0;
  virtual jsi::String base64Decode(jsi::Runtime &rt, jsi::String input) = 0;
  virtual jsi::Object generateECDSAKeyPair(jsi::Runtime &rt) = 0;
  virtual jsi::String getPublicECDSAKey(jsi::Runtime &rt, jsi::String privateECDAkey) = 0;
  virtual jsi::String signDataECDSA(jsi::Runtime &rt, jsi::String data, jsi::String key) = 0;
  virtual bool verifySignatureECDSA(jsi::Runtime &rt, jsi::String data, jsi::String signatureBase64, jsi::String key) = 0;

};

template <typename T>
class JSI_EXPORT NativeEncryptionCxxSpec : public TurboModule {
public:
  jsi::Value get(jsi::Runtime &rt, const jsi::PropNameID &propName) override {
    return delegate_.get(rt, propName);
  }

  static constexpr std::string_view kModuleName = "Encryption";

protected:
  NativeEncryptionCxxSpec(std::shared_ptr<CallInvoker> jsInvoker)
    : TurboModule(std::string{NativeEncryptionCxxSpec::kModuleName}, jsInvoker),
      delegate_(reinterpret_cast<T*>(this), jsInvoker) {}


private:
  class Delegate : public NativeEncryptionCxxSpecJSI {
  public:
    Delegate(T *instance, std::shared_ptr<CallInvoker> jsInvoker) :
      NativeEncryptionCxxSpecJSI(std::move(jsInvoker)), instance_(instance) {

    }

    jsi::String generateAESKey(jsi::Runtime &rt, double keySize) override {
      static_assert(
          bridging::getParameterCount(&T::generateAESKey) == 2,
          "Expected generateAESKey(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::generateAESKey, jsInvoker_, instance_, std::move(keySize));
    }
    jsi::String encryptAES(jsi::Runtime &rt, jsi::String data, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::encryptAES) == 3,
          "Expected encryptAES(...) to have 3 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::encryptAES, jsInvoker_, instance_, std::move(data), std::move(key));
    }
    jsi::String decryptAES(jsi::Runtime &rt, jsi::String data, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::decryptAES) == 3,
          "Expected decryptAES(...) to have 3 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::decryptAES, jsInvoker_, instance_, std::move(data), std::move(key));
    }
    jsi::Value encryptFile(jsi::Runtime &rt, jsi::String inputPath, jsi::String outputPath, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::encryptFile) == 4,
          "Expected encryptFile(...) to have 4 parameters");

      return bridging::callFromJs<jsi::Value>(
          rt, &T::encryptFile, jsInvoker_, instance_, std::move(inputPath), std::move(outputPath), std::move(key));
    }
    jsi::Value decryptFile(jsi::Runtime &rt, jsi::String inputPath, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::decryptFile) == 3,
          "Expected decryptFile(...) to have 3 parameters");

      return bridging::callFromJs<jsi::Value>(
          rt, &T::decryptFile, jsInvoker_, instance_, std::move(inputPath), std::move(key));
    }
    jsi::Value encryptAsyncAES(jsi::Runtime &rt, jsi::String data, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::encryptAsyncAES) == 3,
          "Expected encryptAsyncAES(...) to have 3 parameters");

      return bridging::callFromJs<jsi::Value>(
          rt, &T::encryptAsyncAES, jsInvoker_, instance_, std::move(data), std::move(key));
    }
    jsi::Value decryptAsyncAES(jsi::Runtime &rt, jsi::String data, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::decryptAsyncAES) == 3,
          "Expected decryptAsyncAES(...) to have 3 parameters");

      return bridging::callFromJs<jsi::Value>(
          rt, &T::decryptAsyncAES, jsInvoker_, instance_, std::move(data), std::move(key));
    }
    jsi::Object generateRSAKeyPair(jsi::Runtime &rt) override {
      static_assert(
          bridging::getParameterCount(&T::generateRSAKeyPair) == 1,
          "Expected generateRSAKeyPair(...) to have 1 parameters");

      return bridging::callFromJs<jsi::Object>(
          rt, &T::generateRSAKeyPair, jsInvoker_, instance_);
    }
    jsi::String getPublicRSAkey(jsi::Runtime &rt, jsi::String privateRSAkey) override {
      static_assert(
          bridging::getParameterCount(&T::getPublicRSAkey) == 2,
          "Expected getPublicRSAkey(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::getPublicRSAkey, jsInvoker_, instance_, std::move(privateRSAkey));
    }
    jsi::String encryptRSA(jsi::Runtime &rt, jsi::String data, jsi::String publicKey) override {
      static_assert(
          bridging::getParameterCount(&T::encryptRSA) == 3,
          "Expected encryptRSA(...) to have 3 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::encryptRSA, jsInvoker_, instance_, std::move(data), std::move(publicKey));
    }
    jsi::String decryptRSA(jsi::Runtime &rt, jsi::String data, jsi::String privateKey) override {
      static_assert(
          bridging::getParameterCount(&T::decryptRSA) == 3,
          "Expected decryptRSA(...) to have 3 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::decryptRSA, jsInvoker_, instance_, std::move(data), std::move(privateKey));
    }
    jsi::Value encryptAsyncRSA(jsi::Runtime &rt, jsi::String data, jsi::String publicKey) override {
      static_assert(
          bridging::getParameterCount(&T::encryptAsyncRSA) == 3,
          "Expected encryptAsyncRSA(...) to have 3 parameters");

      return bridging::callFromJs<jsi::Value>(
          rt, &T::encryptAsyncRSA, jsInvoker_, instance_, std::move(data), std::move(publicKey));
    }
    jsi::Value decryptAsyncRSA(jsi::Runtime &rt, jsi::String data, jsi::String privateKey) override {
      static_assert(
          bridging::getParameterCount(&T::decryptAsyncRSA) == 3,
          "Expected decryptAsyncRSA(...) to have 3 parameters");

      return bridging::callFromJs<jsi::Value>(
          rt, &T::decryptAsyncRSA, jsInvoker_, instance_, std::move(data), std::move(privateKey));
    }
    jsi::String hashSHA256(jsi::Runtime &rt, jsi::String input) override {
      static_assert(
          bridging::getParameterCount(&T::hashSHA256) == 2,
          "Expected hashSHA256(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::hashSHA256, jsInvoker_, instance_, std::move(input));
    }
    jsi::String hashSHA512(jsi::Runtime &rt, jsi::String input) override {
      static_assert(
          bridging::getParameterCount(&T::hashSHA512) == 2,
          "Expected hashSHA512(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::hashSHA512, jsInvoker_, instance_, std::move(input));
    }
    jsi::String generateHMACKey(jsi::Runtime &rt, double keySize) override {
      static_assert(
          bridging::getParameterCount(&T::generateHMACKey) == 2,
          "Expected generateHMACKey(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::generateHMACKey, jsInvoker_, instance_, std::move(keySize));
    }
    jsi::String hmacSHA256(jsi::Runtime &rt, jsi::String data, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::hmacSHA256) == 3,
          "Expected hmacSHA256(...) to have 3 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::hmacSHA256, jsInvoker_, instance_, std::move(data), std::move(key));
    }
    jsi::String hmacSHA512(jsi::Runtime &rt, jsi::String data, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::hmacSHA512) == 3,
          "Expected hmacSHA512(...) to have 3 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::hmacSHA512, jsInvoker_, instance_, std::move(data), std::move(key));
    }
    jsi::String generateRandomString(jsi::Runtime &rt, double input) override {
      static_assert(
          bridging::getParameterCount(&T::generateRandomString) == 2,
          "Expected generateRandomString(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::generateRandomString, jsInvoker_, instance_, std::move(input));
    }
    jsi::String base64Encode(jsi::Runtime &rt, jsi::String input) override {
      static_assert(
          bridging::getParameterCount(&T::base64Encode) == 2,
          "Expected base64Encode(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::base64Encode, jsInvoker_, instance_, std::move(input));
    }
    jsi::String base64Decode(jsi::Runtime &rt, jsi::String input) override {
      static_assert(
          bridging::getParameterCount(&T::base64Decode) == 2,
          "Expected base64Decode(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::base64Decode, jsInvoker_, instance_, std::move(input));
    }
    jsi::Object generateECDSAKeyPair(jsi::Runtime &rt) override {
      static_assert(
          bridging::getParameterCount(&T::generateECDSAKeyPair) == 1,
          "Expected generateECDSAKeyPair(...) to have 1 parameters");

      return bridging::callFromJs<jsi::Object>(
          rt, &T::generateECDSAKeyPair, jsInvoker_, instance_);
    }
    jsi::String getPublicECDSAKey(jsi::Runtime &rt, jsi::String privateECDAkey) override {
      static_assert(
          bridging::getParameterCount(&T::getPublicECDSAKey) == 2,
          "Expected getPublicECDSAKey(...) to have 2 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::getPublicECDSAKey, jsInvoker_, instance_, std::move(privateECDAkey));
    }
    jsi::String signDataECDSA(jsi::Runtime &rt, jsi::String data, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::signDataECDSA) == 3,
          "Expected signDataECDSA(...) to have 3 parameters");

      return bridging::callFromJs<jsi::String>(
          rt, &T::signDataECDSA, jsInvoker_, instance_, std::move(data), std::move(key));
    }
    bool verifySignatureECDSA(jsi::Runtime &rt, jsi::String data, jsi::String signatureBase64, jsi::String key) override {
      static_assert(
          bridging::getParameterCount(&T::verifySignatureECDSA) == 4,
          "Expected verifySignatureECDSA(...) to have 4 parameters");

      return bridging::callFromJs<bool>(
          rt, &T::verifySignatureECDSA, jsInvoker_, instance_, std::move(data), std::move(signatureBase64), std::move(key));
    }

  private:
    friend class NativeEncryptionCxxSpec;
    T *instance_;
  };

  Delegate delegate_;
};

} // namespace facebook::react
