///
/// KeyUsage.hpp
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
/// https://github.com/mrousavy/nitro
/// Copyright © Marc Rousavy @ Margelo
///

#pragma once

#if __has_include(<NitroModules/NitroHash.hpp>)
#include <NitroModules/NitroHash.hpp>
#else
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
#endif
#if __has_include(<NitroModules/JSIConverter.hpp>)
#include <NitroModules/JSIConverter.hpp>
#else
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
#endif
#if __has_include(<NitroModules/NitroDefines.hpp>)
#include <NitroModules/NitroDefines.hpp>
#else
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
#endif

namespace margelo::nitro::crypto {

  /**
   * An enum which can be represented as a JavaScript union (KeyUsage).
   */
  enum class KeyUsage {
    ENCRYPT      SWIFT_NAME(encrypt) = 0,
    DECRYPT      SWIFT_NAME(decrypt) = 1,
    SIGN      SWIFT_NAME(sign) = 2,
    VERIFY      SWIFT_NAME(verify) = 3,
    DERIVEKEY      SWIFT_NAME(derivekey) = 4,
    DERIVEBITS      SWIFT_NAME(derivebits) = 5,
    ENCAPSULATEBITS      SWIFT_NAME(encapsulatebits) = 6,
    DECAPSULATEBITS      SWIFT_NAME(decapsulatebits) = 7,
    ENCAPSULATEKEY      SWIFT_NAME(encapsulatekey) = 8,
    DECAPSULATEKEY      SWIFT_NAME(decapsulatekey) = 9,
    WRAPKEY      SWIFT_NAME(wrapkey) = 10,
    UNWRAPKEY      SWIFT_NAME(unwrapkey) = 11,
  } CLOSED_ENUM;

} // namespace margelo::nitro::crypto

namespace margelo::nitro {

  // C++ KeyUsage <> JS KeyUsage (union)
  template <>
  struct JSIConverter<margelo::nitro::crypto::KeyUsage> final {
    static inline margelo::nitro::crypto::KeyUsage fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
      std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
      switch (hashString(unionValue.c_str(), unionValue.size())) {
        case hashString("encrypt"): return margelo::nitro::crypto::KeyUsage::ENCRYPT;
        case hashString("decrypt"): return margelo::nitro::crypto::KeyUsage::DECRYPT;
        case hashString("sign"): return margelo::nitro::crypto::KeyUsage::SIGN;
        case hashString("verify"): return margelo::nitro::crypto::KeyUsage::VERIFY;
        case hashString("deriveKey"): return margelo::nitro::crypto::KeyUsage::DERIVEKEY;
        case hashString("deriveBits"): return margelo::nitro::crypto::KeyUsage::DERIVEBITS;
        case hashString("encapsulateBits"): return margelo::nitro::crypto::KeyUsage::ENCAPSULATEBITS;
        case hashString("decapsulateBits"): return margelo::nitro::crypto::KeyUsage::DECAPSULATEBITS;
        case hashString("encapsulateKey"): return margelo::nitro::crypto::KeyUsage::ENCAPSULATEKEY;
        case hashString("decapsulateKey"): return margelo::nitro::crypto::KeyUsage::DECAPSULATEKEY;
        case hashString("wrapKey"): return margelo::nitro::crypto::KeyUsage::WRAPKEY;
        case hashString("unwrapKey"): return margelo::nitro::crypto::KeyUsage::UNWRAPKEY;
        default: [[unlikely]]
          throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum KeyUsage - invalid value!");
      }
    }
    static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::crypto::KeyUsage arg) {
      switch (arg) {
        case margelo::nitro::crypto::KeyUsage::ENCRYPT: return JSIConverter<std::string>::toJSI(runtime, "encrypt");
        case margelo::nitro::crypto::KeyUsage::DECRYPT: return JSIConverter<std::string>::toJSI(runtime, "decrypt");
        case margelo::nitro::crypto::KeyUsage::SIGN: return JSIConverter<std::string>::toJSI(runtime, "sign");
        case margelo::nitro::crypto::KeyUsage::VERIFY: return JSIConverter<std::string>::toJSI(runtime, "verify");
        case margelo::nitro::crypto::KeyUsage::DERIVEKEY: return JSIConverter<std::string>::toJSI(runtime, "deriveKey");
        case margelo::nitro::crypto::KeyUsage::DERIVEBITS: return JSIConverter<std::string>::toJSI(runtime, "deriveBits");
        case margelo::nitro::crypto::KeyUsage::ENCAPSULATEBITS: return JSIConverter<std::string>::toJSI(runtime, "encapsulateBits");
        case margelo::nitro::crypto::KeyUsage::DECAPSULATEBITS: return JSIConverter<std::string>::toJSI(runtime, "decapsulateBits");
        case margelo::nitro::crypto::KeyUsage::ENCAPSULATEKEY: return JSIConverter<std::string>::toJSI(runtime, "encapsulateKey");
        case margelo::nitro::crypto::KeyUsage::DECAPSULATEKEY: return JSIConverter<std::string>::toJSI(runtime, "decapsulateKey");
        case margelo::nitro::crypto::KeyUsage::WRAPKEY: return JSIConverter<std::string>::toJSI(runtime, "wrapKey");
        case margelo::nitro::crypto::KeyUsage::UNWRAPKEY: return JSIConverter<std::string>::toJSI(runtime, "unwrapKey");
        default: [[unlikely]]
          throw std::invalid_argument("Cannot convert KeyUsage to JS - invalid value: "
                                    + std::to_string(static_cast<int>(arg)) + "!");
      }
    }
    static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
      if (!value.isString()) {
        return false;
      }
      std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
      switch (hashString(unionValue.c_str(), unionValue.size())) {
        case hashString("encrypt"):
        case hashString("decrypt"):
        case hashString("sign"):
        case hashString("verify"):
        case hashString("deriveKey"):
        case hashString("deriveBits"):
        case hashString("encapsulateBits"):
        case hashString("decapsulateBits"):
        case hashString("encapsulateKey"):
        case hashString("decapsulateKey"):
        case hashString("wrapKey"):
        case hashString("unwrapKey"):
          return true;
        default:
          return false;
      }
    }
  };

} // namespace margelo::nitro
