diff --git a/.github/workflows/Deployment.yml b/.github/workflows/Deployment.yml index d12479c25..bdf8218a9 100644 --- a/.github/workflows/Deployment.yml +++ b/.github/workflows/Deployment.yml @@ -26,12 +26,7 @@ on: jobs: deployment: - strategy: - matrix: - include: - - os: macos-latest - os-type: macos - runs-on: ${{ matrix.os }} + runs-on: macos-latest steps: - name: Checkout the repo uses: actions/checkout@v3 @@ -59,36 +54,35 @@ jobs: distribution: zulu - name: "Install NodeJS ${{ env.NODEJS_VERSION }}" - if: matrix.os-type == 'linux' uses: actions/setup-node@v3 with: node-version: "${{ env.NODEJS_VERSION }}" - name: Install Homebrew - if: matrix.os-type == 'macos' run: > /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" - name: "Install autoconf, automake, libtool" - if: matrix.os-type == 'macos' run: | brew install autoconf automake libtool - name: Create Swift Package + env: + TAG_VERSION: ${{github.event.inputs.tag}} run: | - ./gradlew :base-asymmetric-encryption:createSwiftPackage + ./gradlew :apollo:createSwiftPackage - name: Zip framework run: | target_dir_name="Apollo.xcframework" - source_dir="./base-asymmetric-encryption/build/packages/ApolloSwift/" + source_dir="./apollo/build/packages/ApolloSwift/" zip_name="Apollo.xcframework.zip" (cd $source_dir && zip -r "$zip_name" $target_dir_name) - name: Prepare release package run: | - checksum=$(swift package compute-checksum 'base-asymmetric-encryption/build/packages/ApolloSwift/Apollo.xcframework.zip') + checksum=$(swift package compute-checksum 'apollo/build/packages/ApolloSwift/Apollo.xcframework.zip') echo "CHECKSUM: $checksum" rm -f Package.swift || true ./.scripts/updatePackage.swift ${{github.event.inputs.tag}} $checksum './.scripts/TemplatePackage.swift' 'Package.swift' @@ -106,19 +100,18 @@ jobs: uses: actions/upload-artifact@v3 with: name: Apollo.xcframework.zip - path: base-asymmetric-encryption/build/packages/ApolloSwift/Apollo.xcframework.zip + path: apollo/build/packages/ApolloSwift/Apollo.xcframework.zip - name: Add swift package artifacts to release uses: svenstaro/upload-release-action@v2 with: tag: ${{github.event.inputs.tag}} - file: base-asymmetric-encryption/build/packages/ApolloSwift/Apollo.xcframework.zip + file: apollo/build/packages/ApolloSwift/Apollo.xcframework.zip asset_name: "Apollo.xcframework.zip" - name: Publish Maven artifacts to Github Packages + env: + TAG_VERSION: ${{github.event.inputs.tag}} id: publish run: | - ./gradlew publishAllPublicationsToGitHubPackagesRepository :base-asymmetric-encryption:publishJsPackageToGithubRegistry - - - + ./gradlew :apollo:publishAllPublicationsToGitHubPackagesRepository \ No newline at end of file diff --git a/Package.swift b/Package.swift index 4234c34ee..7e1940daf 100644 --- a/Package.swift +++ b/Package.swift @@ -23,8 +23,8 @@ let package = Package( // RELEASE .binaryTarget( name: "ApolloBinary", - url: "https://github.com/input-output-hk/atala-prism-apollo/releases/download/testSwift2/Apollo.xcframework.zip", - checksum: "817420e940206f912c5dcf92acb3b38bd2b87caef6caebc707ff1ff98c5778b8" + url: "https://github.com/input-output-hk/atala-prism-apollo/releases/download/1.0.6/Apollo.xcframework.zip", + checksum: "a59700e70a374ddf9176b7ea0ee8d5467734df88900e346617cc19fbd8adc87b" ) ] ) diff --git a/aes/README.md b/aes/README.md deleted file mode 100644 index aae882433..000000000 --- a/aes/README.md +++ /dev/null @@ -1,59 +0,0 @@ -# Apollo - AES - -[![Kotlin](https://img.shields.io/badge/kotlin-1.7.21-blue.svg?logo=kotlin)](http://kotlinlang.org) - -![android](https://camo.githubusercontent.com/b1d9ad56ab51c4ad1417e9a5ad2a8fe63bcc4755e584ec7defef83755c23f923/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d616e64726f69642d3645444238442e7376673f7374796c653d666c6174) -![apple-silicon](https://camo.githubusercontent.com/a92c841ffd377756a144d5723ff04ecec886953d40ac03baa738590514714921/687474703a2f2f696d672e736869656c64732e696f2f62616467652f737570706f72742d2535424170706c6553696c69636f6e2535442d3433424246462e7376673f7374796c653d666c6174) -![ios](https://camo.githubusercontent.com/1fec6f0d044c5e1d73656bfceed9a78fd4121b17e82a2705d2a47f6fd1f0e3e5/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d696f732d4344434443442e7376673f7374796c653d666c6174) -![jvm](https://camo.githubusercontent.com/700f5dcd442fd835875568c038ae5cd53518c80ae5a0cf12c7c5cf4743b5225b/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6a766d2d4442343133442e7376673f7374796c653d666c6174) -![js](https://camo.githubusercontent.com/3e0a143e39915184b54b60a2ecedec75e801f396d34b5b366c94ec3604f7e6bd/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6a732d4638444235442e7376673f7374796c653d666c6174) -![getNode-js](https://camo.githubusercontent.com/d08fda729ceebcae0f23c83499ca8f06105350f037661ac9a4cc7f58edfdbca9/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6e6f64656a732d3638613036332e7376673f7374796c653d666c6174) -![macos](https://camo.githubusercontent.com/1b8313498db244646b38a4480186ae2b25464e5e8d71a1920c52b2be5212b909/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6d61636f732d3131313131312e7376673f7374796c653d666c6174) -![tvos](https://camo.githubusercontent.com/4ac08d7fb1bcb8ef26388cd2bf53b49626e1ab7cbda581162a946dd43e6a2726/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d74766f732d3830383038302e7376673f7374796c653d666c6174) -![watchos](https://camo.githubusercontent.com/135dbadae40f9cabe7a3a040f9380fb485cff36c90909f3c1ae36b81c304426b/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d77617463686f732d4330433043302e7376673f7374796c653d666c6174) - -Apollo AES is Kotlin Multiplatform library for AES encryption & decryption with the following supports. - -## Supported Key Size - -- 128 -- 192 -- 256 - -## Supported Block Mode - -- ECB -- CBC -- CFB -- CFB8 -- CTR -- GCM -- OFB -- RC4 - -## Supported Padding - -- No Padding -- PKCS5 -- PKCS7 - -## Usage - -```kotlin -val text = "Welcome to IOG!" -val algo = KAESAlgorithm.AES_256 -val key = AES.createRandomAESKey(algo) -val aes = AES( - algo, - KAESBlockMode.GCM, - KAESPadding.No_Padding, - key, - KMMSymmetricKey.createRandomIV(16) -) -val encryptedBytes = aes.encrypt(text.encodeToByteArray()) -val decryptedBytes = aes.decrypt(encryptedBytes) -``` - -## TODO - -* Update supported Block Mode to the only ones supported per platform. \ No newline at end of file diff --git a/aes/aes.podspec b/aes/aes.podspec deleted file mode 100644 index 6a8a5aa59..000000000 --- a/aes/aes.podspec +++ /dev/null @@ -1,43 +0,0 @@ -Pod::Spec.new do |spec| - spec.name = 'aes' - spec.version = '1.7.0-alpha' - spec.homepage = '' - spec.source = { :http=> ''} - spec.authors = 'IOG' - spec.license = '' - spec.summary = 'ApolloAES is an AES lib' - spec.vendored_frameworks = 'build/cocoapods/framework/ApolloAES.framework' - spec.libraries = 'c++' - spec.ios.deployment_target = '13.0' - spec.osx.deployment_target = '12.0' - spec.tvos.deployment_target = '13.0' - spec.watchos.deployment_target = '8.0' - spec.dependency 'IOHKAES', '1.0.0' - spec.dependency 'IOHKSecureRandomGeneration', '1.0.0' - - spec.pod_target_xcconfig = { - 'KOTLIN_PROJECT_PATH' => ':aes', - 'PRODUCT_MODULE_NAME' => 'ApolloAES', - } - - spec.script_phases = [ - { - :name => 'Build aes', - :execution_position => :before_compile, - :shell_path => '/bin/sh', - :script => <<-SCRIPT - if [ "YES" = "$OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED" ]; then - echo "Skipping Gradle build task invocation due to OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED environment variable set to \"YES\"" - exit 0 - fi - set -ev - REPO_ROOT="$PODS_TARGET_SRCROOT" - "$REPO_ROOT/../gradlew" -p "$REPO_ROOT" $KOTLIN_PROJECT_PATH:syncFramework \ - -Pkotlin.native.cocoapods.platform=$PLATFORM_NAME \ - -Pkotlin.native.cocoapods.archs="$ARCHS" \ - -Pkotlin.native.cocoapods.configuration="$CONFIGURATION" - SCRIPT - } - ] - -end \ No newline at end of file diff --git a/aes/karma.config.d/karma.config.js b/aes/karma.config.d/karma.config.js deleted file mode 100644 index e56914aa1..000000000 --- a/aes/karma.config.d/karma.config.js +++ /dev/null @@ -1,9 +0,0 @@ -config.set({ - browserDisconnectTimeout: 300000, - processKillTimeout: 300000, - client: { - mocha: { - timeout: 300000 - } - } -}); diff --git a/aes/src/androidMain/AndroidManifest.xml b/aes/src/androidMain/AndroidManifest.xml deleted file mode 100644 index 232c3f49e..000000000 --- a/aes/src/androidMain/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt b/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt deleted file mode 100644 index 476d6408d..000000000 --- a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt +++ /dev/null @@ -1,65 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.KMMSymmetricKey -import java.security.spec.AlgorithmParameterSpec -import javax.crypto.Cipher -import javax.crypto.KeyGenerator -import javax.crypto.spec.GCMParameterSpec -import javax.crypto.spec.IvParameterSpec - -actual typealias KAESAlgorithmNativeType = String -actual typealias KAESBlockModeNativeType = String -actual typealias KAESPaddingNativeType = String - -actual final class AES actual constructor( - actual val algorithm: KAESAlgorithm, - actual val blockMode: KAESBlockMode, - actual val padding: KAESPadding, - actual val key: KMMSymmetricKey, - actual val iv: ByteArray? -) : AESEncryptor, AESDecryptor { - - private val cipher: Cipher = Cipher.getInstance("${algorithm.nativeValue()}/${blockMode.nativeValue()}/${padding.nativeValue()}") - private val ivSpec: AlgorithmParameterSpec? = if (blockMode.needIV()) { - when (blockMode) { - KAESBlockMode.ECB -> IvParameterSpec(iv) - KAESBlockMode.CBC -> IvParameterSpec(iv) - KAESBlockMode.CFB -> IvParameterSpec(iv) - KAESBlockMode.CFB8 -> IvParameterSpec(iv) - KAESBlockMode.CTR -> IvParameterSpec(iv) - KAESBlockMode.GCM -> GCMParameterSpec(AUTH_TAG_SIZE, iv) - KAESBlockMode.OFB -> IvParameterSpec(iv) - KAESBlockMode.RC4 -> IvParameterSpec(iv) - } - } else { - null - } - - override suspend fun encrypt(data: ByteArray): ByteArray { - if (ivSpec == null) { - cipher.init(Cipher.ENCRYPT_MODE, key.nativeType) - } else { - cipher.init(Cipher.ENCRYPT_MODE, key.nativeType, ivSpec) - } - return cipher.doFinal(data) - } - - override suspend fun decrypt(data: ByteArray): ByteArray { - if (ivSpec == null) { - cipher.init(Cipher.DECRYPT_MODE, key.nativeType) - } else { - cipher.init(Cipher.DECRYPT_MODE, key.nativeType, ivSpec) - } - return cipher.doFinal(data) - } - - actual companion object : AESKeyGeneration { - private const val AUTH_TAG_SIZE = 128 - - override suspend fun createRandomAESKey(algorithm: KAESAlgorithm, blockMode: KAESBlockMode): KMMSymmetricKey { - val keygen = KeyGenerator.getInstance("AES") - keygen.init(algorithm.keySize()) - return KMMSymmetricKey(keygen.generateKey()) - } - } -} diff --git a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt b/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt deleted file mode 100644 index f68fa3ef6..000000000 --- a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt +++ /dev/null @@ -1,11 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESAlgorithm : NativeTypeInterface { - AES_128, - AES_192, - AES_256; - - override fun nativeValue() = "AES" -} diff --git a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt b/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt deleted file mode 100644 index 471df724e..000000000 --- a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt +++ /dev/null @@ -1,27 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESBlockMode : NativeTypeInterface { - ECB, - CBC, - CFB, - CFB8, - CTR, - GCM, - OFB, - RC4; - - override fun nativeValue(): KAESBlockModeNativeType { - return when (this) { - ECB -> "ECB" - CBC -> "CBC" - CFB -> "CFB" - CFB8 -> "CFB8" - CTR -> "CTR" - GCM -> "GCM" - OFB -> "OFB" - RC4 -> throw Exception("Not implemented in JVM") - } - } -} diff --git a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt b/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt deleted file mode 100644 index 9c7ee7237..000000000 --- a/aes/src/androidMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt +++ /dev/null @@ -1,17 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESPadding : NativeTypeInterface { - NO_PADDING, - PKCS5PADDING, - PKCS7PADDING; - - override fun nativeValue(): KAESPaddingNativeType { - return when (this) { - NO_PADDING -> "NoPadding" - PKCS5PADDING -> "PKCS5Padding" - PKCS7PADDING -> "PKCS5Padding" - } - } -} diff --git a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt b/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt deleted file mode 100644 index b3b058ac9..000000000 --- a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt +++ /dev/null @@ -1,23 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.KMMSymmetricKey - -expect class KAESAlgorithmNativeType -expect class KAESBlockModeNativeType -expect class KAESPaddingNativeType - -expect final class AES( - algorithm: KAESAlgorithm, - blockMode: KAESBlockMode, - padding: KAESPadding, - key: KMMSymmetricKey, - iv: ByteArray? -) : AESEncryptor, AESDecryptor { - val algorithm: KAESAlgorithm - val blockMode: KAESBlockMode - val padding: KAESPadding - val key: KMMSymmetricKey - val iv: ByteArray? - - companion object : AESKeyGeneration -} diff --git a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESDecryptor.kt b/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESDecryptor.kt deleted file mode 100644 index 7d8d4a778..000000000 --- a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESDecryptor.kt +++ /dev/null @@ -1,5 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -interface AESDecryptor { - suspend fun decrypt(data: ByteArray): ByteArray -} diff --git a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESEncryptor.kt b/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESEncryptor.kt deleted file mode 100644 index 3a8b8e983..000000000 --- a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESEncryptor.kt +++ /dev/null @@ -1,5 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -interface AESEncryptor { - suspend fun encrypt(data: ByteArray): ByteArray -} diff --git a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESKeyGeneration.kt b/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESKeyGeneration.kt deleted file mode 100644 index dc849c085..000000000 --- a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/AESKeyGeneration.kt +++ /dev/null @@ -1,12 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.KMMSymmetricKey - -interface AESKeyGeneration { - /** - * Generate random AES key - * - * @param algorithm AES Key algorithm - */ - suspend fun createRandomAESKey(algorithm: KAESAlgorithm, blockMode: KAESBlockMode = KAESBlockMode.GCM): KMMSymmetricKey -} diff --git a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt b/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt deleted file mode 100644 index 58ef1546a..000000000 --- a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt +++ /dev/null @@ -1,22 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface -import kotlin.js.ExperimentalJsExport -import kotlin.js.JsExport - -expect enum class KAESAlgorithm : NativeTypeInterface { - AES_128, - AES_192, - AES_256 -} - -@OptIn(ExperimentalJsExport::class) -@JsExport -fun KAESAlgorithm.keySize(): Int { - return when (this) { - KAESAlgorithm.AES_128 -> 128 - KAESAlgorithm.AES_192 -> 192 - KAESAlgorithm.AES_256 -> 256 - else -> throw Exception("This line should never be reached") - } -} diff --git a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt b/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt deleted file mode 100644 index f2a98c7a2..000000000 --- a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt +++ /dev/null @@ -1,23 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -expect enum class KAESBlockMode : NativeTypeInterface { - ECB, - CBC, - CFB, - CFB8, - CTR, - GCM, - OFB, - RC4 -} - -fun KAESBlockMode.needIV(): Boolean { - return when (this) { - KAESBlockMode.ECB -> false - KAESBlockMode.CBC, KAESBlockMode.CFB, KAESBlockMode.CFB8, KAESBlockMode.CTR, KAESBlockMode.GCM, - KAESBlockMode.OFB, KAESBlockMode.RC4 -> true - else -> throw IllegalStateException("Should never reach this line") - } -} diff --git a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt b/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt deleted file mode 100644 index 7184aa504..000000000 --- a/aes/src/commonMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt +++ /dev/null @@ -1,9 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -expect enum class KAESPadding : NativeTypeInterface { - NO_PADDING, - PKCS5PADDING, - PKCS7PADDING -} diff --git a/aes/src/commonTest/kotlin/io/iohk/atala/prism/apollo/aes/AESTests.kt b/aes/src/commonTest/kotlin/io/iohk/atala/prism/apollo/aes/AESTests.kt deleted file mode 100644 index 3bbd20e76..000000000 --- a/aes/src/commonTest/kotlin/io/iohk/atala/prism/apollo/aes/AESTests.kt +++ /dev/null @@ -1,59 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.KMMSymmetricKey -import io.iohk.atala.prism.apollo.utils.SymmetricKeyType -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.runTest -import kotlin.test.Test -import kotlin.test.assertEquals - -class AESTests { - @OptIn(ExperimentalCoroutinesApi::class) - @Test - fun testAESGCM() = runTest { - val text = "Welcome to IOG!" - val algo = KAESAlgorithm.AES_256 - val key = AES.createRandomAESKey(algo) - val aes = AES( - algo, - KAESBlockMode.GCM, - KAESPadding.NO_PADDING, - key, - KMMSymmetricKey.createRandomIV(16) - ) - val encryptedBytes = aes.encrypt(text.encodeToByteArray()) - val decryptedBytes = aes.decrypt(encryptedBytes) - assertEquals(text, decryptedBytes.decodeToString()) - } - - @OptIn(ExperimentalCoroutinesApi::class) - @Test - fun testAESCBC() = runTest { - val text = "Welcome to IOG!" - val algo = KAESAlgorithm.AES_256 - val key = AES.createRandomAESKey(algo) - val aes = AES( - algo, - KAESBlockMode.CBC, - KAESPadding.PKCS5PADDING, - key, - KMMSymmetricKey.createRandomIV(16) - ) - val encryptedBytes = aes.encrypt(text.encodeToByteArray()) - val decryptedBytes = aes.decrypt(encryptedBytes) - assertEquals(text, decryptedBytes.decodeToString()) - } - - @OptIn(ExperimentalCoroutinesApi::class) - @Test - fun testAESKeyExportImport() = runTest { - val algo = KAESAlgorithm.AES_256 - val key = AES.createRandomAESKey(algo) - - val base64Key = key.exportToBase64() - - val importedKey = KMMSymmetricKey.createKeyFromBase64(base64Key, SymmetricKeyType.AES) - - assertEquals(base64Key, importedKey.exportToBase64()) - } -} diff --git a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt b/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt deleted file mode 100644 index e1dee0b53..000000000 --- a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt +++ /dev/null @@ -1,64 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import cocoapods.IOHKAES.AESOptionsNone -import cocoapods.IOHKAES.AESOptionsPkcs7Padding -import cocoapods.IOHKAES.IOHKAES -import io.iohk.atala.prism.apollo.utils.KMMSymmetricKey -import io.iohk.atala.prism.apollo.utils.toByteArray -import io.iohk.atala.prism.apollo.utils.toNSData -import kotlinx.cinterop.autoreleasepool -import platform.Foundation.NSData - -actual typealias KAESAlgorithmNativeType = Long -actual typealias KAESBlockModeNativeType = Int -actual typealias KAESPaddingNativeType = Long - -actual final class AES actual constructor( - actual val algorithm: KAESAlgorithm, - actual val blockMode: KAESBlockMode, - actual val padding: KAESPadding, - actual val key: KMMSymmetricKey, - actual val iv: ByteArray? -) : AESEncryptor, AESDecryptor { - override suspend fun encrypt(data: ByteArray): ByteArray { - autoreleasepool { - val encryptedData = IOHKAES.aesEncryptionWithAlgorithm( - algorithm.nativeValue(), - AESOptionsPkcs7Padding, - blockMode.nativeValue().toUInt(), - padding.nativeValue(), - data.toNSData(), - key.nativeValue, - iv?.toNSData() ?: NSData() - )?.toByteArray() - - return encryptedData ?: ByteArray(0) - } - } - - override suspend fun decrypt(data: ByteArray): ByteArray { - autoreleasepool { - val decryptedData = IOHKAES.aesDecryptionWithAlgorithm( - algorithm.nativeValue(), - AESOptionsNone, - blockMode.nativeValue().toUInt(), - padding.nativeValue(), - data.toNSData(), - key.nativeValue, - iv?.toNSData() ?: NSData() - )?.toByteArray() - - return decryptedData ?: ByteArray(0) - } - } - - actual companion object : AESKeyGeneration { - override suspend fun createRandomAESKey(algorithm: KAESAlgorithm, blockMode: KAESBlockMode): KMMSymmetricKey { - autoreleasepool { - return KMMSymmetricKey( - IOHKAES.generateAESKeyWithAlgorithm(algorithm.nativeValue()) - ) - } - } - } -} diff --git a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt b/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt deleted file mode 100644 index f6d2e2d01..000000000 --- a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt +++ /dev/null @@ -1,20 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import cocoapods.IOHKAES.AESAlgorithmAes128 -import cocoapods.IOHKAES.AESAlgorithmAes192 -import cocoapods.IOHKAES.AESAlgorithmAes256 -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESAlgorithm : NativeTypeInterface { - AES_128, - AES_192, - AES_256; - - override fun nativeValue(): KAESAlgorithmNativeType { - return when (this) { - AES_128 -> AESAlgorithmAes128 - AES_192 -> AESAlgorithmAes192 - AES_256 -> AESAlgorithmAes256 - } - } -} diff --git a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt b/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt deleted file mode 100644 index 06b1d21da..000000000 --- a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt +++ /dev/null @@ -1,35 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import cocoapods.IOHKAES.BlockModeCbc -import cocoapods.IOHKAES.BlockModeCfb -import cocoapods.IOHKAES.BlockModeCfb8 -import cocoapods.IOHKAES.BlockModeCtr -import cocoapods.IOHKAES.BlockModeEcb -import cocoapods.IOHKAES.BlockModeGcm -import cocoapods.IOHKAES.BlockModeOfb -import cocoapods.IOHKAES.BlockModeRc4 -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESBlockMode : NativeTypeInterface { - ECB, - CBC, - CFB, - CFB8, - CTR, - GCM, - OFB, - RC4; - - override fun nativeValue(): KAESBlockModeNativeType { - return when (this) { - ECB -> BlockModeEcb.toInt() - CBC -> BlockModeCbc.toInt() - CFB -> BlockModeCfb.toInt() - CFB8 -> BlockModeCfb8.toInt() - CTR -> BlockModeCtr.toInt() - GCM -> BlockModeGcm.toInt() - OFB -> BlockModeOfb.toInt() - RC4 -> BlockModeRc4.toInt() - } - } -} diff --git a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt b/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt deleted file mode 100644 index 37f023965..000000000 --- a/aes/src/iosMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt +++ /dev/null @@ -1,20 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import cocoapods.IOHKAES.PaddingNoPadding -import cocoapods.IOHKAES.PaddingPkcs7Padding -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESPadding : NativeTypeInterface { - NO_PADDING, - PKCS5PADDING, - PKCS7PADDING; - - override fun nativeValue(): KAESPaddingNativeType { - return when (this) { - NO_PADDING -> PaddingNoPadding - // PKCS#5 padding and PKCS#7 padding are practically the same => https://crypto.stackexchange.com/questions/9043/what-is-the-difference-between-pkcs5-padding-and-pkcs7-padding/9044#9044 - PKCS5PADDING -> PaddingPkcs7Padding - PKCS7PADDING -> PaddingPkcs7Padding - } - } -} diff --git a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt b/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt deleted file mode 100644 index 5707e845e..000000000 --- a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt +++ /dev/null @@ -1,119 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.KMMSymmetricKey -import io.iohk.atala.prism.apollo.utils.toArrayBuffer -import io.iohk.atala.prism.apollo.utils.toByteArray -import kotlinx.coroutines.MainScope -import kotlinx.coroutines.await -import kotlinx.coroutines.promise -import web.crypto.AesCbcParams -import web.crypto.AesGcmParams -import web.crypto.AesKeyAlgorithm -import web.crypto.AesKeyGenParams -import web.crypto.Algorithm -import web.crypto.KeyFormat -import web.crypto.KeyUsage -import web.crypto.crypto - -actual typealias KAESAlgorithmNativeType = String -actual typealias KAESBlockModeNativeType = String -actual typealias KAESPaddingNativeType = String - -actual final class AES actual constructor( - actual val algorithm: KAESAlgorithm, - actual val blockMode: KAESBlockMode, - actual val padding: KAESPadding, - actual val key: KMMSymmetricKey, - actual val iv: ByteArray? -) : AESEncryptor, AESDecryptor { - - private fun getAesKeyAlgorithm(): AesKeyAlgorithm { - val algorithmString = "${algorithm.nativeValue()}-${blockMode.nativeValue()}" - val length = this.algorithm.keySize() - return js("{name: algorithmString, length: length}").unsafeCast() - } - - private fun getAesParams(): Algorithm { - val algorithmString = "${algorithm.nativeValue()}-${blockMode.nativeValue()}" - return if (blockMode.needIV()) { - val jsIV = this.iv!!.toArrayBuffer() - when (blockMode) { - KAESBlockMode.GCM -> { - val tagSize = GCM_AUTH_TAG_SIZE - js("{name: algorithmString, iv: jsIV, tagLength: tagSize}").unsafeCast() - } - KAESBlockMode.CBC -> { - js("{name: algorithmString, iv: jsIV}").unsafeCast() - } - else -> { - throw NotImplementedError("Yet to be implemented") - } - } - } else { - js("{name: algorithmString}").unsafeCast() - } - } - - override suspend fun encrypt(data: ByteArray): ByteArray { - return MainScope().promise { - val nativeKey = key.nativeValue - - val cryptoKey = crypto.subtle.importKey( - KeyFormat.raw, - nativeKey.toArrayBuffer(), - getAesKeyAlgorithm(), - true, - arrayOf(KeyUsage.encrypt, KeyUsage.decrypt) - ).await() - - crypto.subtle.encrypt( - getAesParams(), - cryptoKey, - data.toArrayBuffer() - ).await().toByteArray() - }.await() - } - - override suspend fun decrypt(data: ByteArray): ByteArray { - return MainScope().promise { - val nativeKey = key.nativeValue - - val cryptoKey = crypto.subtle.importKey( - KeyFormat.raw, - nativeKey.toArrayBuffer(), - getAesKeyAlgorithm(), - true, - arrayOf(KeyUsage.encrypt, KeyUsage.decrypt) - ).await() - - crypto.subtle.decrypt( - getAesParams(), - cryptoKey, - data.toArrayBuffer() - ).await().toByteArray() - }.await() - } - - actual companion object : AESKeyGeneration { - // Because NITS recommends it to always be 128 or bigger https://csrc.nist.gov/publications/detail/sp/800-38d/final - private const val GCM_AUTH_TAG_SIZE = 128 - - private fun getAesKeyGenParams(algorithm: KAESAlgorithm, blockMode: KAESBlockMode): AesKeyGenParams { - val algorithmString = "${algorithm.nativeValue()}-${blockMode.nativeValue()}" - val keyLength = algorithm.keySize() - return js("{name: algorithmString, length: keyLength}").unsafeCast() - } - - override suspend fun createRandomAESKey(algorithm: KAESAlgorithm, blockMode: KAESBlockMode): KMMSymmetricKey { - return MainScope().promise { - val cryptoKey = crypto.subtle.generateKey( - getAesKeyGenParams(algorithm, blockMode), - true, - arrayOf(KeyUsage.encrypt, KeyUsage.decrypt) - ).await() - val key = crypto.subtle.exportKey(KeyFormat.raw, cryptoKey).await().toByteArray() - KMMSymmetricKey(key) - }.await() - } - } -} diff --git a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt b/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt deleted file mode 100644 index 40dfbd497..000000000 --- a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt +++ /dev/null @@ -1,19 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -@OptIn(ExperimentalJsExport::class) -@JsExport -actual enum class KAESAlgorithm : NativeTypeInterface { - AES_128, - AES_192, - AES_256; - - override fun nativeValue(): KAESAlgorithmNativeType { - return when (this) { - AES_128 -> "AES" - AES_192 -> "AES" - AES_256 -> "AES" - } - } -} diff --git a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt b/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt deleted file mode 100644 index 80c70ca37..000000000 --- a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt +++ /dev/null @@ -1,29 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -@OptIn(ExperimentalJsExport::class) -@JsExport -actual enum class KAESBlockMode : NativeTypeInterface { - ECB, - CBC, - CFB, - CFB8, - CTR, - GCM, - OFB, - RC4; - - override fun nativeValue(): KAESBlockModeNativeType { - return when (this) { - ECB -> throw NotImplementedError() - CBC -> "CBC" - CFB -> throw NotImplementedError() - CFB8 -> throw NotImplementedError() - CTR -> "CTR" - GCM -> "GCM" - OFB -> throw NotImplementedError() - RC4 -> throw NotImplementedError() - } - } -} diff --git a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt b/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt deleted file mode 100644 index 92ae3eaf5..000000000 --- a/aes/src/jsMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt +++ /dev/null @@ -1,19 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -@OptIn(ExperimentalJsExport::class) -@JsExport -actual enum class KAESPadding : NativeTypeInterface { - NO_PADDING, - PKCS5PADDING, - PKCS7PADDING; - - override fun nativeValue(): KAESPaddingNativeType { - return when (this) { - NO_PADDING -> "" - PKCS5PADDING -> "" - PKCS7PADDING -> "" - } - } -} diff --git a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt b/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt deleted file mode 100644 index 476d6408d..000000000 --- a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/AES.kt +++ /dev/null @@ -1,65 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.KMMSymmetricKey -import java.security.spec.AlgorithmParameterSpec -import javax.crypto.Cipher -import javax.crypto.KeyGenerator -import javax.crypto.spec.GCMParameterSpec -import javax.crypto.spec.IvParameterSpec - -actual typealias KAESAlgorithmNativeType = String -actual typealias KAESBlockModeNativeType = String -actual typealias KAESPaddingNativeType = String - -actual final class AES actual constructor( - actual val algorithm: KAESAlgorithm, - actual val blockMode: KAESBlockMode, - actual val padding: KAESPadding, - actual val key: KMMSymmetricKey, - actual val iv: ByteArray? -) : AESEncryptor, AESDecryptor { - - private val cipher: Cipher = Cipher.getInstance("${algorithm.nativeValue()}/${blockMode.nativeValue()}/${padding.nativeValue()}") - private val ivSpec: AlgorithmParameterSpec? = if (blockMode.needIV()) { - when (blockMode) { - KAESBlockMode.ECB -> IvParameterSpec(iv) - KAESBlockMode.CBC -> IvParameterSpec(iv) - KAESBlockMode.CFB -> IvParameterSpec(iv) - KAESBlockMode.CFB8 -> IvParameterSpec(iv) - KAESBlockMode.CTR -> IvParameterSpec(iv) - KAESBlockMode.GCM -> GCMParameterSpec(AUTH_TAG_SIZE, iv) - KAESBlockMode.OFB -> IvParameterSpec(iv) - KAESBlockMode.RC4 -> IvParameterSpec(iv) - } - } else { - null - } - - override suspend fun encrypt(data: ByteArray): ByteArray { - if (ivSpec == null) { - cipher.init(Cipher.ENCRYPT_MODE, key.nativeType) - } else { - cipher.init(Cipher.ENCRYPT_MODE, key.nativeType, ivSpec) - } - return cipher.doFinal(data) - } - - override suspend fun decrypt(data: ByteArray): ByteArray { - if (ivSpec == null) { - cipher.init(Cipher.DECRYPT_MODE, key.nativeType) - } else { - cipher.init(Cipher.DECRYPT_MODE, key.nativeType, ivSpec) - } - return cipher.doFinal(data) - } - - actual companion object : AESKeyGeneration { - private const val AUTH_TAG_SIZE = 128 - - override suspend fun createRandomAESKey(algorithm: KAESAlgorithm, blockMode: KAESBlockMode): KMMSymmetricKey { - val keygen = KeyGenerator.getInstance("AES") - keygen.init(algorithm.keySize()) - return KMMSymmetricKey(keygen.generateKey()) - } - } -} diff --git a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt b/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt deleted file mode 100644 index f68fa3ef6..000000000 --- a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESAlgorithm.kt +++ /dev/null @@ -1,11 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESAlgorithm : NativeTypeInterface { - AES_128, - AES_192, - AES_256; - - override fun nativeValue() = "AES" -} diff --git a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt b/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt deleted file mode 100644 index 471df724e..000000000 --- a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESBlockMode.kt +++ /dev/null @@ -1,27 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESBlockMode : NativeTypeInterface { - ECB, - CBC, - CFB, - CFB8, - CTR, - GCM, - OFB, - RC4; - - override fun nativeValue(): KAESBlockModeNativeType { - return when (this) { - ECB -> "ECB" - CBC -> "CBC" - CFB -> "CFB" - CFB8 -> "CFB8" - CTR -> "CTR" - GCM -> "GCM" - OFB -> "OFB" - RC4 -> throw Exception("Not implemented in JVM") - } - } -} diff --git a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt b/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt deleted file mode 100644 index 9c7ee7237..000000000 --- a/aes/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/aes/KAESPadding.kt +++ /dev/null @@ -1,17 +0,0 @@ -package io.iohk.atala.prism.apollo.aes - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual enum class KAESPadding : NativeTypeInterface { - NO_PADDING, - PKCS5PADDING, - PKCS7PADDING; - - override fun nativeValue(): KAESPaddingNativeType { - return when (this) { - NO_PADDING -> "NoPadding" - PKCS5PADDING -> "PKCS5Padding" - PKCS7PADDING -> "PKCS5Padding" - } - } -} diff --git a/aes/webpack.config.d/polyfill.js b/aes/webpack.config.d/polyfill.js deleted file mode 100644 index 26262794b..000000000 --- a/aes/webpack.config.d/polyfill.js +++ /dev/null @@ -1,6 +0,0 @@ -config.resolve = { - fallback: { - crypto: require.resolve('crypto-browserify'), - stream: require.resolve("stream-browserify") - } -}; diff --git a/apollo/build.gradle.kts b/apollo/build.gradle.kts index ca8136edf..678616b93 100644 --- a/apollo/build.gradle.kts +++ b/apollo/build.gradle.kts @@ -1,3 +1,4 @@ +import dev.petuska.npm.publish.extension.domain.NpmAccess import org.gradle.internal.os.OperatingSystem import org.jetbrains.dokka.gradle.DokkaTask import org.jetbrains.kotlin.gradle.targets.js.webpack.KotlinWebpackOutput.Target @@ -7,8 +8,10 @@ val os: OperatingSystem = OperatingSystem.current() plugins { kotlin("multiplatform") + id("io.github.luca992.multiplatform-swiftpackage") version "2.0.5-arm64" id("com.android.library") id("org.jetbrains.dokka") + id("dev.petuska.npm.publish") version "3.4.1" } kotlin { @@ -25,11 +28,41 @@ kotlin { useJUnitPlatform() } } - if (os.isMacOsX) { - ios() - iosSimulatorArm64() - macosArm64() + + ios { + binaries.framework { + export(project(":cryptography")) + export(project(":multibase")) + export(project(":base64")) + export(project(":base58")) + export(project(":base32")) + export(project(":utils")) + export(project(":hashing")) + } + } + iosSimulatorArm64() { + binaries.framework { + export(project(":cryptography")) + export(project(":multibase")) + export(project(":base64")) + export(project(":base58")) + export(project(":base32")) + export(project(":utils")) + export(project(":hashing")) + } + } + macosArm64() { + binaries.framework { + export(project(":cryptography")) + export(project(":multibase")) + export(project(":base64")) + export(project(":base58")) + export(project(":base32")) + export(project(":utils")) + export(project(":hashing")) + } } + js(IR) { this.moduleName = currentModuleName this.binaries.library() @@ -66,9 +99,24 @@ kotlin { } } + multiplatformSwiftPackage { + packageName("Apollo") + swiftToolsVersion("5.3") + targetPlatforms { + iOS { v("13") } + macOS { v("11") } + } + outputDirectory(File(rootDir, "apollo/build/packages/ApolloSwift")) + } + sourceSets { val commonMain by getting { dependencies { + api(project(":cryptography")) + api(project(":multibase")) + api(project(":base64")) + api(project(":base58")) + api(project(":base32")) api(project(":utils")) api(project(":hashing")) implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.4.1") @@ -91,21 +139,31 @@ kotlin { implementation("junit:junit:4.13.2") } } - val jsMain by getting - val jsTest by getting - if (os.isMacOsX) { - val iosMain by getting - val iosTest by getting + val jsMain by getting { + dependencies { + implementation(npm("elliptic", "6.5.4")) + implementation(npm("@types/elliptic", "6.4.14")) + implementation(npm("@noble/curves", "1.2.0")) + implementation(npm("@stablelib/x25519", "1.0.3")) - val iosSimulatorArm64Main by getting { - this.dependsOn(iosMain) - } - val iosSimulatorArm64Test by getting { - this.dependsOn(iosTest) + // Polyfill dependencies + implementation(npm("stream-browserify", "3.0.0")) + implementation(npm("buffer", "6.0.3")) } - val macosArm64Main by getting - val macosArm64Test by getting } + val jsTest by getting + + val iosMain by getting + val iosTest by getting + + val iosSimulatorArm64Main by getting { + this.dependsOn(iosMain) + } + val iosSimulatorArm64Test by getting { + this.dependsOn(iosTest) + } + val macosArm64Main by getting + val macosArm64Test by getting } if (os.isMacOsX) { @@ -156,3 +214,33 @@ tasks.withType { } } } + +npmPublish { + organization.set("input-output-hk") + version.set("1.0.6") + access.set(NpmAccess.PUBLIC) + packages { + access.set(NpmAccess.PUBLIC) + named("js") { + scope.set("input-output-hk") + packageName.set("apollo") + packageJson { + author { + name.set("IOG") + } + repository { + type.set("git") + url.set("https://github.com/input-output-hk/atala-prism-apollo.git") + } + } + } + } + registries { + access.set(NpmAccess.PUBLIC) + github { + uri.set("https://npm.pkg.github.com/") + access.set(NpmAccess.PUBLIC) + this.authToken.set(System.getenv("ATALA_GITHUB_TOKEN")) + } + } +} diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/secp256k1/secp256k1js.kt b/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/secp256k1/secp256k1js.kt deleted file mode 100644 index 3af6f4c04..000000000 --- a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/secp256k1/secp256k1js.kt +++ /dev/null @@ -1,253 +0,0 @@ -// Automatically generated by dukat and then slightly adjusted manually to make it compile -@file:Suppress("ktlint") -// @file:Suppress("INTERFACE_WITH_SUPERCLASS", "OVERRIDING_FINAL_MEMBER", "RETURN_TYPE_MISMATCH_ON_OVERRIDE", "CONFLICTING_OVERLOADS") -@file:JsModule("@noble/secp256k1") -/* ktlint-disable */ -package io.iohk.atala.prism.apollo.utils.external.secp256k1 - -import io.iohk.atala.prism.apollo.utils.external.BN -import kotlin.js.* -import org.khronos.webgl.* -import org.w3c.dom.* -import org.w3c.dom.events.* -import org.w3c.dom.parsing.* -import org.w3c.dom.svg.* -import org.w3c.dom.url.* -import org.w3c.fetch.* -import org.w3c.files.* -import org.w3c.notifications.* -import org.w3c.performance.* -import org.w3c.workers.* -import org.w3c.xhr.* -import org.khronos.webgl.Uint8Array - -external object CURVE { - var p: BN - var n: BN - var a: BN - var b: BN - var Gx: BN - var Gy: BN -} - -external interface AffinePoint { - var x: BN - var y: BN -} - -external open class Point(px: BN, py: BN, pz: BN) { - open var px: BN - open var py: BN - open var pz: BN - open fun equals(other: Point): Boolean - open fun negate(): Point - open fun double(): Point - open fun add(other: Point): Point - open fun mul(n: BN, safe: Boolean = definedExternally): Point - open fun mulAddQUns(R: Point, u1: BN, u2: BN): Point - open fun toAffine(): AffinePoint - open fun assertValidity(): Point - open fun multiply(n: BN): Point - open fun aff(): AffinePoint - open fun ok(): Point - open fun toHex(isCompressed: Boolean = definedExternally): String - open fun toRawBytes(isCompressed: Boolean = definedExternally): Uint8Array - - companion object { - var BASE: Point - var ZERO: Point - fun fromAffine(p: AffinePoint): Point - fun fromHex(hex: Uint8Array): Point - fun fromHex(hex: String): Point - fun fromPrivateKey(k: Uint8Array): Point - fun fromPrivateKey(k: String): Point - fun fromPrivateKey(k: BN): Point - } -} - -external fun getPublicKey(privKey: Uint8Array, isCompressed: Boolean = definedExternally): Uint8Array - -external fun getPublicKey(privKey: Uint8Array): Uint8Array - -external fun getPublicKey(privKey: String, isCompressed: Boolean = definedExternally): Uint8Array - -external fun getPublicKey(privKey: String): Uint8Array - -external fun getPublicKey(privKey: BN, isCompressed: Boolean = definedExternally): Uint8Array - -external fun getPublicKey(privKey: BN): Uint8Array - -external open class Signature(r: BN, s: BN, recovery: BN? = definedExternally) { - open var r: BN - open var s: BN - open var recovery: BN? - open fun assertValidity(): Signature /* this */ - open fun addRecoveryBit(rec: BN): Signature /* Signature & `T$2` */ - open fun hasHighS(): Boolean - open fun recoverPublicKey(msgh: Uint8Array): Point - open fun recoverPublicKey(msgh: String): Point - open fun toCompactRawBytes(): Uint8Array - open fun toCompactHex(): String - - companion object { - fun fromCompact(hex: Uint8Array): Signature - fun fromCompact(hex: String): Signature - } -} - -external interface `T$0` { - var lowS: Boolean? - get() = definedExternally - set(value) = definedExternally - var extraEntropy: dynamic /* Boolean? | Uint8Array? | String? */ - get() = definedExternally - set(value) = definedExternally -} - -external fun signAsync(msgh: Uint8Array, priv: Uint8Array, opts: `T$0` = definedExternally): Promise - -external fun signAsync(msgh: Uint8Array, priv: Uint8Array): Promise - -external fun signAsync(msgh: Uint8Array, priv: String, opts: `T$0` = definedExternally): Promise - -external fun signAsync(msgh: Uint8Array, priv: String): Promise - -external fun signAsync(msgh: Uint8Array, priv: BN, opts: `T$0` = definedExternally): Promise - -external fun signAsync(msgh: Uint8Array, priv: BN): Promise - -external fun signAsync(msgh: String, priv: Uint8Array, opts: `T$0` = definedExternally): Promise - -external fun signAsync(msgh: String, priv: Uint8Array): Promise - -external fun signAsync(msgh: String, priv: String, opts: `T$0` = definedExternally): Promise - -external fun signAsync(msgh: String, priv: String): Promise - -external fun signAsync(msgh: String, priv: BN, opts: `T$0` = definedExternally): Promise - -external fun signAsync(msgh: String, priv: BN): Promise - -external fun sign(msgh: Uint8Array, priv: Uint8Array, opts: `T$0` = definedExternally): Signature /* Signature & `T$2` */ - -external fun sign(msgh: Uint8Array, priv: Uint8Array): Signature /* Signature & `T$2` */ - -external fun sign(msgh: Uint8Array, priv: String, opts: `T$0` = definedExternally): Signature /* Signature & `T$2` */ - -external fun sign(msgh: Uint8Array, priv: String): Signature /* Signature & `T$2` */ - -external fun sign(msgh: Uint8Array, priv: BN, opts: `T$0` = definedExternally): Signature /* Signature & `T$2` */ - -external fun sign(msgh: Uint8Array, priv: BN): Signature /* Signature & `T$2` */ - -external fun sign(msgh: String, priv: Uint8Array, opts: `T$0` = definedExternally): Signature /* Signature & `T$2` */ - -external fun sign(msgh: String, priv: Uint8Array): Signature /* Signature & `T$2` */ - -external fun sign(msgh: String, priv: String, opts: `T$0` = definedExternally): Signature /* Signature & `T$2` */ - -external fun sign(msgh: String, priv: String): Signature /* Signature & `T$2` */ - -external fun sign(msgh: String, priv: Any, opts: `T$0` = definedExternally): Signature /* Signature & `T$2` */ - -external fun sign(msgh: String, priv: Any): Signature /* Signature & `T$2` */ - -external interface SigLike { - var r: BN - var s: BN -} - -external interface `T$1` { - var lowS: Boolean? - get() = definedExternally - set(value) = definedExternally -} - -external fun verify(sig: Uint8Array, msgh: Uint8Array, pub: Uint8Array, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: Uint8Array, msgh: Uint8Array, pub: Uint8Array): Boolean - -external fun verify(sig: Uint8Array, msgh: Uint8Array, pub: String, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: Uint8Array, msgh: Uint8Array, pub: String): Boolean - -external fun verify(sig: Uint8Array, msgh: String, pub: Uint8Array, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: Uint8Array, msgh: String, pub: Uint8Array): Boolean - -external fun verify(sig: Uint8Array, msgh: String, pub: String, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: Uint8Array, msgh: String, pub: String): Boolean - -external fun verify(sig: String, msgh: Uint8Array, pub: Uint8Array, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: String, msgh: Uint8Array, pub: Uint8Array): Boolean - -external fun verify(sig: String, msgh: Uint8Array, pub: String, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: String, msgh: Uint8Array, pub: String): Boolean - -external fun verify(sig: String, msgh: String, pub: Uint8Array, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: String, msgh: String, pub: Uint8Array): Boolean - -external fun verify(sig: String, msgh: String, pub: String, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: String, msgh: String, pub: String): Boolean - -external fun verify(sig: SigLike, msgh: Uint8Array, pub: Uint8Array, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: SigLike, msgh: Uint8Array, pub: Uint8Array): Boolean - -external fun verify(sig: SigLike, msgh: Uint8Array, pub: String, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: SigLike, msgh: Uint8Array, pub: String): Boolean - -external fun verify(sig: SigLike, msgh: String, pub: Uint8Array, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: SigLike, msgh: String, pub: Uint8Array): Boolean - -external fun verify(sig: SigLike, msgh: String, pub: String, opts: `T$1` = definedExternally): Boolean - -external fun verify(sig: SigLike, msgh: String, pub: String): Boolean - -external fun getSharedSecret(privA: Uint8Array, pubB: Uint8Array, isCompressed: Boolean = definedExternally): Uint8Array - -external fun getSharedSecret(privA: Uint8Array, pubB: Uint8Array): Uint8Array - -external fun getSharedSecret(privA: Uint8Array, pubB: String, isCompressed: Boolean = definedExternally): Uint8Array - -external fun getSharedSecret(privA: Uint8Array, pubB: String): Uint8Array - -external fun getSharedSecret(privA: String, pubB: Uint8Array, isCompressed: Boolean = definedExternally): Uint8Array - -external fun getSharedSecret(privA: String, pubB: Uint8Array): Uint8Array - -external fun getSharedSecret(privA: String, pubB: String, isCompressed: Boolean = definedExternally): Uint8Array - -external fun getSharedSecret(privA: String, pubB: String): Uint8Array - -external fun hashToPrivateKey(hash: Uint8Array): Uint8Array - -external fun hashToPrivateKey(hash: String): Uint8Array - -external object etc { - var hexToBytes: (hex: String) -> Uint8Array - var bytesToHex: (b: Uint8Array) -> String - var concatBytes: (arrs: Uint8Array) -> Uint8Array - var bytesToNumberBE: (b: Uint8Array) -> Any - var numberToBytesBE: (num: Any) -> Uint8Array - var mod: (a: Any, b: Any) -> Any - var invert: (num: Any, md: Any) -> Any - var hmacSha256Async: (key: Uint8Array, msgs: Uint8Array) -> Promise - var hmacSha256Sync: ((key: Uint8Array, msgs: Uint8Array) -> Uint8Array)? - var hashToPrivateKey: Any - var randomBytes: (len: BN) -> Uint8Array -} - -external object utils { - var normPrivateKeyToScalar: (p: dynamic /* Uint8Array | String | Any */) -> Any - var isValidPrivateKey: (key: dynamic /* Uint8Array | String */) -> Boolean - var randomPrivateKey: () -> Uint8Array - fun precompute(w: BN = definedExternally, p: Point = definedExternally): Point -} \ No newline at end of file diff --git a/base-symmetric-encryption/build.gradle.kts b/base-symmetric-encryption/build.gradle.kts deleted file mode 100644 index 8644853da..000000000 --- a/base-symmetric-encryption/build.gradle.kts +++ /dev/null @@ -1,194 +0,0 @@ -import org.gradle.internal.os.OperatingSystem -import org.jetbrains.dokka.gradle.DokkaTask -import org.jetbrains.kotlin.gradle.targets.js.webpack.KotlinWebpackOutput.Target - -val currentModuleName = "ApolloBaseSymmetricEncryption" -val os: OperatingSystem = OperatingSystem.current() - -plugins { - kotlin("multiplatform") - id("com.android.library") - id("org.jetbrains.dokka") -} - -kotlin { - android { - publishAllLibraryVariants() - } - jvm { - compilations.all { - kotlinOptions { - jvmTarget = "11" - } - } - testRuns["test"].executionTask.configure { - useJUnitPlatform() - } - } - if (os.isMacOsX) { - ios() -// tvos() -// watchos() - iosSimulatorArm64() -// tvosSimulatorArm64() -// watchosSimulatorArm64() - macosArm64() - } -// if (os.isWindows) { -// // mingwX86() // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// mingwX64() -// } - js(IR) { - this.moduleName = currentModuleName - this.binaries.library() - this.useCommonJs() - generateTypeScriptDefinitions() - this.compilations["main"].packageJson { - this.version = rootProject.version.toString() - } - this.compilations["test"].packageJson { - this.version = rootProject.version.toString() - } - browser { - this.webpackTask { - this.output.library = currentModuleName - this.output.libraryTarget = Target.VAR - } - this.commonWebpackConfig { - } - this.testTask { - if (os.isWindows) { - this.enabled = false - } - this.useKarma { - this.useChromeHeadless() - } - } - } - nodejs { - this.testTask { - if (os.isWindows) { - this.enabled = false - } - this.useKarma { - this.useChromeHeadless() - } - } - } - } - - sourceSets { - val commonMain by getting { - dependencies { - implementation(project(":secure-random")) - implementation(project(":base64")) - } - } - val commonTest by getting { - dependencies { - implementation(kotlin("test")) - } - } - val jvmMain by getting - val jvmTest by getting - val androidMain by getting - val androidTest by getting { - dependencies { - implementation("junit:junit:4.13.2") - } - } - val jsMain by getting { - dependencies { - implementation("org.jetbrains.kotlin-wrappers:kotlin-web:1.0.0-pre.461") - implementation("org.jetbrains.kotlin-wrappers:kotlin-node:18.11.13-pre.461") - } - } - val jsTest by getting - if (os.isMacOsX) { - val iosMain by getting - val iosTest by getting -// val tvosMain by getting -// val tvosTest by getting -// val watchosMain by getting -// val watchosTest by getting - val iosSimulatorArm64Main by getting { - this.dependsOn(iosMain) - } - val iosSimulatorArm64Test by getting { - this.dependsOn(iosTest) - } -// val tvosSimulatorArm64Main by getting { -// this.dependsOn(tvosMain) -// } -// val tvosSimulatorArm64Test by getting { -// this.dependsOn(tvosTest) -// } -// val watchosSimulatorArm64Main by getting { -// this.dependsOn(watchosMain) -// } -// val watchosSimulatorArm64Test by getting { -// this.dependsOn(watchosTest) -// } - val macosArm64Main by getting { - this.dependsOn(iosMain) - } - val macosArm64Test by getting { - this.dependsOn(iosTest) - } - } -// if (os.isWindows) { -// // val mingwX86Main by getting // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// // val mingwX86Test by getting // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// val mingwX64Main by getting -// val mingwX64Test by getting -// } - } - - if (os.isMacOsX) { - tasks.getByName("iosX64Test") { - device.set("iPhone 14 Plus") - } - tasks.getByName("iosSimulatorArm64Test") { - device.set("iPhone 14 Plus") - } - } -} - -android { - compileSdk = 32 - sourceSets["main"].manifest.srcFile("src/androidMain/AndroidManifest.xml") - defaultConfig { - minSdk = 21 - targetSdk = 32 - } - compileOptions { - sourceCompatibility = JavaVersion.VERSION_11 - targetCompatibility = JavaVersion.VERSION_11 - } - /** - * Because Software Components will not be created automatically for Maven publishing from - * Android Gradle Plugin 8.0. To opt-in to the future behavior, set the Gradle property android. - * disableAutomaticComponentCreation=true in the `gradle.properties` file or use the new - * publishing DSL. - */ - publishing { - multipleVariants { - withSourcesJar() - withJavadocJar() - allVariants() - } - } -} - -// Dokka implementation -tasks.withType { - moduleName.set(project.name) - moduleVersion.set(rootProject.version.toString()) - description = "This is a Kotlin Multiplatform Library for Base Symmetric Encryption" - dokkaSourceSets { - // TODO: Figure out how to include files to the documentations - named("commonMain") { - includes.from("Module.md", "docs/Module.md") - } - } -} diff --git a/base-symmetric-encryption/src/androidMain/AndroidManifest.xml b/base-symmetric-encryption/src/androidMain/AndroidManifest.xml deleted file mode 100644 index 1ddfad099..000000000 --- a/base-symmetric-encryption/src/androidMain/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/base-symmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt b/base-symmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt deleted file mode 100644 index b8a637ba7..000000000 --- a/base-symmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt +++ /dev/null @@ -1,20 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import io.iohk.atala.prism.apollo.base64.base64PadDecodedBytes -import io.iohk.atala.prism.apollo.base64.base64PadEncoded -import javax.crypto.SecretKey -import javax.crypto.spec.SecretKeySpec - -actual open class KMMSymmetricKey(val nativeType: SecretKey) : SymmetricKeyBase64Export { - override fun exportToBase64(): String { - return nativeType.encoded.base64PadEncoded - } - - actual companion object : SymmetricKeyBase64Import, IVBase64Import, IVBase64Export, IVGeneration { - override fun createKeyFromBase64(base64Encoded: String, algorithm: SymmetricKeyType): KMMSymmetricKey { - val decodedKey = base64Encoded.base64PadDecodedBytes - val originalKey: SecretKey = SecretKeySpec(decodedKey, 0, decodedKey.size, algorithm.value) - return KMMSymmetricKey(originalKey) - } - } -} diff --git a/base-symmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt b/base-symmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt deleted file mode 100644 index 9edaf17a9..000000000 --- a/base-symmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt +++ /dev/null @@ -1,5 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -actual enum class SymmetricKeyType(val value: String) { - AES("AES"); -} diff --git a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVBase64Export.kt b/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVBase64Export.kt deleted file mode 100644 index b917c91d3..000000000 --- a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVBase64Export.kt +++ /dev/null @@ -1,14 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import io.iohk.atala.prism.apollo.base64.base64PadEncoded - -interface IVBase64Export { - /** - * Export IV to Base64 standard with padding - * - * @param iv iv value to convert to Base64 standard with padding - */ - fun exportToBase64(iv: ByteArray): String { - return iv.base64PadEncoded - } -} diff --git a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVBase64Import.kt b/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVBase64Import.kt deleted file mode 100644 index ed237bec9..000000000 --- a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVBase64Import.kt +++ /dev/null @@ -1,14 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import io.iohk.atala.prism.apollo.base64.base64PadDecodedBytes - -interface IVBase64Import { - /** - * Create an IV from Base64 standard with padding - * - * @param base64Encoded Base64 standard with padding value to convert to IV - */ - fun createIVFromBase64(base64Encoded: String): ByteArray { - return base64Encoded.base64PadDecodedBytes - } -} diff --git a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVGeneration.kt b/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVGeneration.kt deleted file mode 100644 index 04ac31aee..000000000 --- a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/IVGeneration.kt +++ /dev/null @@ -1,12 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import io.iohk.atala.prism.apollo.securerandom.SecureRandom - -interface IVGeneration { - /** - * Generate random data with specified size - * - * @param size the size of the random generated data - */ - fun createRandomIV(size: Int): ByteArray = SecureRandom().nextBytes(size) -} diff --git a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt b/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt deleted file mode 100644 index 730dd2d33..000000000 --- a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt +++ /dev/null @@ -1,5 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -expect open class KMMSymmetricKey : SymmetricKeyBase64Export { - companion object : SymmetricKeyBase64Import, IVBase64Import, IVBase64Export, IVGeneration -} diff --git a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyBase64Export.kt b/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyBase64Export.kt deleted file mode 100644 index 998529672..000000000 --- a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyBase64Export.kt +++ /dev/null @@ -1,8 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -public interface SymmetricKeyBase64Export { - /** - * export [KMMSymmetricKey] to Base64 standard with padding - */ - fun exportToBase64(): String -} diff --git a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyBase64Import.kt b/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyBase64Import.kt deleted file mode 100644 index a7a38964d..000000000 --- a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyBase64Import.kt +++ /dev/null @@ -1,11 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -public interface SymmetricKeyBase64Import { - /** - * Create an instance of [KMMSymmetricKey] from a Base64 standard with padding encoded key - * - * @param base64Encoded a Base64 standard with padding encoded key value - * @param algorithm algorithm type supported - */ - fun createKeyFromBase64(base64Encoded: String, algorithm: SymmetricKeyType): KMMSymmetricKey -} diff --git a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt b/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt deleted file mode 100644 index bf30bff06..000000000 --- a/base-symmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt +++ /dev/null @@ -1,5 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -expect enum class SymmetricKeyType { - AES -} diff --git a/base-symmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKeyTests.kt b/base-symmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKeyTests.kt deleted file mode 100644 index edc19840b..000000000 --- a/base-symmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKeyTests.kt +++ /dev/null @@ -1,11 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import kotlin.test.Test -import kotlin.test.assertEquals - -class KMMSymmetricKeyTests { - @Test - fun test() { - assertEquals(1, 1) - } -} diff --git a/base-symmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt b/base-symmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt deleted file mode 100644 index 800149c9e..000000000 --- a/base-symmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt +++ /dev/null @@ -1,17 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import io.iohk.atala.prism.apollo.base64.base64PadDecodedBytes -import io.iohk.atala.prism.apollo.base64.base64PadEncoded -import platform.Foundation.NSData - -actual open class KMMSymmetricKey(val nativeValue: NSData) : SymmetricKeyBase64Export { - override fun exportToBase64(): String { - return nativeValue.toByteArray().base64PadEncoded - } - - actual companion object : SymmetricKeyBase64Import, IVBase64Import, IVBase64Export, IVGeneration { - override fun createKeyFromBase64(base64Encoded: String, algorithm: SymmetricKeyType): KMMSymmetricKey { - return KMMSymmetricKey(base64Encoded.base64PadDecodedBytes.toNSData()) - } - } -} diff --git a/base-symmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt b/base-symmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt deleted file mode 100644 index ff0e79f15..000000000 --- a/base-symmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt +++ /dev/null @@ -1,5 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -actual enum class SymmetricKeyType { - AES -} diff --git a/base-symmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt b/base-symmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt deleted file mode 100644 index 588581a91..000000000 --- a/base-symmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt +++ /dev/null @@ -1,18 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import io.iohk.atala.prism.apollo.base64.base64PadDecodedBytes -import io.iohk.atala.prism.apollo.base64.base64PadEncoded - -@OptIn(ExperimentalJsExport::class) -@JsExport -actual open class KMMSymmetricKey(val nativeValue: ByteArray) : SymmetricKeyBase64Export { - override fun exportToBase64(): String { - return nativeValue.base64PadEncoded - } - - actual companion object : SymmetricKeyBase64Import, IVBase64Import, IVBase64Export, IVGeneration { - override fun createKeyFromBase64(base64Encoded: String, algorithm: SymmetricKeyType): KMMSymmetricKey { - return KMMSymmetricKey(base64Encoded.base64PadDecodedBytes) - } - } -} diff --git a/base-symmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt b/base-symmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt deleted file mode 100644 index 88bf48f70..000000000 --- a/base-symmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt +++ /dev/null @@ -1,7 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -@OptIn(ExperimentalJsExport::class) -@JsExport -actual enum class SymmetricKeyType { - AES; -} diff --git a/base-symmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt b/base-symmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt deleted file mode 100644 index b8a637ba7..000000000 --- a/base-symmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMSymmetricKey.kt +++ /dev/null @@ -1,20 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -import io.iohk.atala.prism.apollo.base64.base64PadDecodedBytes -import io.iohk.atala.prism.apollo.base64.base64PadEncoded -import javax.crypto.SecretKey -import javax.crypto.spec.SecretKeySpec - -actual open class KMMSymmetricKey(val nativeType: SecretKey) : SymmetricKeyBase64Export { - override fun exportToBase64(): String { - return nativeType.encoded.base64PadEncoded - } - - actual companion object : SymmetricKeyBase64Import, IVBase64Import, IVBase64Export, IVGeneration { - override fun createKeyFromBase64(base64Encoded: String, algorithm: SymmetricKeyType): KMMSymmetricKey { - val decodedKey = base64Encoded.base64PadDecodedBytes - val originalKey: SecretKey = SecretKeySpec(decodedKey, 0, decodedKey.size, algorithm.value) - return KMMSymmetricKey(originalKey) - } - } -} diff --git a/base-symmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt b/base-symmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt deleted file mode 100644 index 9edaf17a9..000000000 --- a/base-symmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/SymmetricKeyType.kt +++ /dev/null @@ -1,5 +0,0 @@ -package io.iohk.atala.prism.apollo.utils - -actual enum class SymmetricKeyType(val value: String) { - AES("AES"); -} diff --git a/build.gradle.kts b/build.gradle.kts index bcce562a9..d4b9ec93e 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -21,7 +21,7 @@ buildscript { } } -version = "1.0.2" +version = System.getenv("TAG_VERSION") ?: "1.0.3" group = "io.iohk.atala.prism.apollo" dependencies { @@ -34,11 +34,10 @@ dependencies { kover(project(":base64")) kover(project(":multibase")) kover(project(":utils")) - kover(project(":base-symmetric-encryption")) + kover(project(":cryptography")) kover(project(":secure-random")) // kover(project(":aes")) - kover(project(":base-asymmetric-encryption")) -// kover(project(":rsa")) + // kover(project(":rsa")) // kover(project(":ecdsa")) kover(project(":varint")) // kover(project(":jose")) @@ -47,7 +46,7 @@ dependencies { } allprojects { - version = "1.0.2" + version = System.getenv("TAG_VERSION") ?: "1.0.3" group = "io.iohk.atala.prism.apollo" repositories { diff --git a/base-asymmetric-encryption/build.gradle.kts b/cryptography/build.gradle.kts similarity index 86% rename from base-asymmetric-encryption/build.gradle.kts rename to cryptography/build.gradle.kts index a23967f46..3e1949d5f 100644 --- a/base-asymmetric-encryption/build.gradle.kts +++ b/cryptography/build.gradle.kts @@ -1,17 +1,14 @@ -import dev.petuska.npm.publish.extension.domain.NpmAccess import org.gradle.internal.os.OperatingSystem import org.jetbrains.dokka.gradle.DokkaTask import org.jetbrains.kotlin.gradle.targets.js.webpack.KotlinWebpackOutput.Target -val currentModuleName = "ApolloBaseAsymmetricEncryption" +val currentModuleName = "Cryptography" val os: OperatingSystem = OperatingSystem.current() plugins { kotlin("multiplatform") - id("io.github.luca992.multiplatform-swiftpackage") version "2.0.5-arm64" id("com.android.library") id("org.jetbrains.dokka") - id("dev.petuska.npm.publish") version "3.4.1" } kotlin { @@ -116,16 +113,6 @@ kotlin { } } - multiplatformSwiftPackage { - packageName("Apollo") - swiftToolsVersion("5.3") - targetPlatforms { - iOS { v("13") } - macOS { v("11") } - } - outputDirectory(File(rootDir, "base-asymmetric-encryption/build/packages/ApolloSwift")) - } - sourceSets { val commonMain by getting { dependencies { @@ -183,7 +170,7 @@ kotlin { implementation(npm("elliptic", "6.5.4")) implementation(npm("@types/elliptic", "6.4.14")) - implementation(npm("@noble/secp256k1", "2.0.0")) + implementation(npm("@noble/curves", "1.2.0")) implementation(npm("@stablelib/x25519", "1.0.3")) // Polyfill dependencies @@ -287,33 +274,3 @@ ktlint { exclude { projectDir.toURI().relativize(it.file.toURI()).path.contains("/external/") } } } - -npmPublish { - organization.set("input-output-hk") - version.set(project.version.toString()) - access.set(NpmAccess.PUBLIC) - packages { - access.set(NpmAccess.PUBLIC) - named("js") { - scope.set("input-output-hk") - packageName.set("apollo") - packageJson { - author { - name.set("IOG") - } - repository { - type.set("git") - url.set("https://github.com/input-output-hk/atala-prism-apollo.git") - } - } - } - } - registries { - access.set(NpmAccess.PUBLIC) - github { - uri.set("https://npm.pkg.github.com/") - access.set(NpmAccess.PUBLIC) - this.authToken.set(System.getenv("ATALA_GITHUB_TOKEN")) - } - } -} diff --git a/base-asymmetric-encryption/src/androidMain/AndroidManifest.xml b/cryptography/src/androidMain/AndroidManifest.xml similarity index 100% rename from base-asymmetric-encryption/src/androidMain/AndroidManifest.xml rename to cryptography/src/androidMain/AndroidManifest.xml diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt diff --git a/base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt b/cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt similarity index 100% rename from base-asymmetric-encryption/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt rename to cryptography/src/androidMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationAxis.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationAxis.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationAxis.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationAxis.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationPath.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationPath.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationPath.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/DerivationPath.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyOptions.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyOptions.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyOptions.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyOptions.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCodeEnglish.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCodeEnglish.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCodeEnglish.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCodeEnglish.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicException.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicException.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicException.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicException.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicHelper.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicHelper.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicHelper.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicHelper.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECConfig.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECConfig.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECConfig.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECConfig.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECKeyExceptions.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECKeyExceptions.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECKeyExceptions.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/ECKeyExceptions.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Ed25519KeyPairGeneration.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Ed25519KeyPairGeneration.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Ed25519KeyPairGeneration.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Ed25519KeyPairGeneration.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Encodable.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Encodable.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Encodable.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/Encodable.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPoint.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPoint.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPoint.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPoint.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PrivateKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PrivateKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PrivateKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PublicKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PublicKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1PublicKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEllipticCurve.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEllipticCurve.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEllipticCurve.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEllipticCurve.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/X25519KeyPairGeneration.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/X25519KeyPairGeneration.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/X25519KeyPairGeneration.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/X25519KeyPairGeneration.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/MnemonicException.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/MnemonicException.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/MnemonicException.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/MnemonicException.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeCzech.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeCzech.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeCzech.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeCzech.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeEnglish.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeEnglish.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeEnglish.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeEnglish.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeFrench.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeFrench.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeFrench.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeFrench.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeItalian.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeItalian.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeItalian.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeItalian.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeJapanese.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeJapanese.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeJapanese.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeJapanese.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeKorean.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeKorean.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeKorean.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeKorean.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSimplifiedChinese.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSimplifiedChinese.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSimplifiedChinese.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSimplifiedChinese.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSpanish.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSpanish.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSpanish.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeSpanish.kt diff --git a/base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeTraditionalChinese.kt b/cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeTraditionalChinese.kt similarity index 100% rename from base-asymmetric-encryption/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeTraditionalChinese.kt rename to cryptography/src/commonMain/kotlin/io/iohk/atala/prism/apollo/utils/bip39/wordlists/MnemonicCodeTraditionalChinese.kt diff --git a/base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyTest.kt b/cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyTest.kt similarity index 100% rename from base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyTest.kt rename to cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/derivation/HDKeyTest.kt diff --git a/base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1KeysTests.kt b/cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1KeysTests.kt similarity index 100% rename from base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1KeysTests.kt rename to cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMECSecp256k1KeysTests.kt diff --git a/base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTestsIgnored.kt b/cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTestsIgnored.kt similarity index 100% rename from base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTestsIgnored.kt rename to cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTestsIgnored.kt diff --git a/base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPairTests.kt b/cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPairTests.kt similarity index 100% rename from base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPairTests.kt rename to cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPairTests.kt diff --git a/base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/MnemonicTests.kt b/cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/MnemonicTests.kt similarity index 100% rename from base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/MnemonicTests.kt rename to cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/MnemonicTests.kt diff --git a/base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1LibTests.kt b/cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1LibTests.kt similarity index 100% rename from base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1LibTests.kt rename to cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1LibTests.kt diff --git a/base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1TestVectors.kt b/cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1TestVectors.kt similarity index 100% rename from base-asymmetric-encryption/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1TestVectors.kt rename to cryptography/src/commonTest/kotlin/io/iohk/atala/prism/apollo/utils/Secp256k1TestVectors.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDH.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDH.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDH.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDH.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDSA.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDSA.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDSA.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/ECDSA.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Hex.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Hex.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Hex.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Hex.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Schnorr.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Schnorr.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Schnorr.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Schnorr.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Exception.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Exception.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Exception.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Exception.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt diff --git a/base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt b/cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt similarity index 100% rename from base-asymmetric-encryption/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt rename to cryptography/src/iosMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt diff --git a/base-asymmetric-encryption/src/iosTest/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Tests.kt b/cryptography/src/iosTest/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Tests.kt similarity index 100% rename from base-asymmetric-encryption/src/iosTest/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Tests.kt rename to cryptography/src/iosTest/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Tests.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt similarity index 94% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt index aba30eea6..6af05918e 100644 --- a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt +++ b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt @@ -9,11 +9,11 @@ import io.iohk.atala.prism.apollo.utils.asUint8Array import io.iohk.atala.prism.apollo.utils.decodeHex import io.iohk.atala.prism.apollo.utils.external.BN import io.iohk.atala.prism.apollo.utils.external.ec -import io.iohk.atala.prism.apollo.utils.external.secp256k1.getPublicKey +import io.iohk.atala.prism.apollo.utils.external.secp256k1.secp256k1 actual class Secp256k1Lib actual constructor() { actual fun createPublicKey(privateKey: ByteArray, compressed: Boolean): ByteArray { - return getPublicKey(privateKey.asUint8Array(), isCompressed = compressed).asByteArray() + return secp256k1.getPublicKey(privateKey.asUint8Array(), compressed).asByteArray() } actual fun derivePrivateKey(privateKeyBytes: ByteArray, derivedPrivateKeyBytes: ByteArray): ByteArray? { diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/Curve25519Parser.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/Curve25519Parser.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/Curve25519Parser.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/Curve25519Parser.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/JsHashType.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/JsHashType.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/JsHashType.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/JsHashType.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPointJS.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPointJS.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPointJS.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMECPointJS.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP32.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP32.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP32.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP32.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP39.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP39.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP39.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BIP39.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BNjs.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BNjs.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BNjs.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/BNjs.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Curve.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Curve.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Curve.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Curve.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Ellipticjs.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Ellipticjs.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Ellipticjs.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Ellipticjs.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/PresetCurve.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/PresetCurve.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/PresetCurve.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/PresetCurve.kt diff --git a/base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Stabelib.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Stabelib.kt similarity index 100% rename from base-asymmetric-encryption/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Stabelib.kt rename to cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/Stabelib.kt diff --git a/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/secp256k1/secp256k1js.kt b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/secp256k1/secp256k1js.kt new file mode 100644 index 000000000..06bbc0083 --- /dev/null +++ b/cryptography/src/jsMain/kotlin/io/iohk/atala/prism/apollo/utils/external/secp256k1/secp256k1js.kt @@ -0,0 +1,96 @@ +// Automatically generated by dukat and then slightly adjusted manually to make it compile +@file:Suppress("ktlint") +// @file:Suppress("INTERFACE_WITH_SUPERCLASS", "OVERRIDING_FINAL_MEMBER", "RETURN_TYPE_MISMATCH_ON_OVERRIDE", "CONFLICTING_OVERLOADS") +@file:JsModule("@noble/curves/secp256k1") +/* ktlint-disable */ +package io.iohk.atala.prism.apollo.utils.external.secp256k1 + +import io.iohk.atala.prism.apollo.utils.external.BN +import kotlin.js.* +import org.khronos.webgl.* +import org.w3c.dom.* +import org.w3c.dom.events.* +import org.w3c.dom.parsing.* +import org.w3c.dom.svg.* +import org.w3c.dom.url.* +import org.w3c.fetch.* +import org.w3c.files.* +import org.w3c.notifications.* +import org.w3c.performance.* +import org.w3c.workers.* +import org.w3c.xhr.* +import org.khronos.webgl.Uint8Array + +external interface `T$0` { + var k1neg: Boolean + var k1: Any + var k2neg: Boolean + var k2: Any +} + +external interface `T$1` { + var beta: Any + var splitScalar: (k: Any) -> `T$0` +} + + +external interface `T$2` { + var nBitLength: Number + var nByteLength: Number + var Fp: Any + var n: Any + var h: Any + var hEff: Any? + get() = definedExternally + set(value) = definedExternally + var Gx: Any + var Gy: Any + var allowInfinityPoint: Boolean? + get() = definedExternally + set(value) = definedExternally + var a: Any + var b: Any + var allowedPrivateKeyLengths: Array? + get() = definedExternally + set(value) = definedExternally + var wrapPrivateKey: Boolean? + get() = definedExternally + set(value) = definedExternally + var endo: `T$1`? + get() = definedExternally + set(value) = definedExternally + var hash: Any + var hmac: (key: Uint8Array, messages: Uint8Array) -> Uint8Array + var randomBytes: (bytesLength: Number?) -> Uint8Array + var lowS: Boolean + var bits2int: ((bytes: Uint8Array) -> Any)? + get() = definedExternally + set(value) = definedExternally + var bits2int_modN: ((bytes: Uint8Array) -> Any)? + get() = definedExternally + set(value) = definedExternally + var p: Any +} + +external interface `T$4` { + var normPrivateKeyToScalar: (key: dynamic /* Uint8Array | String | Any */) -> Any + fun isValidPrivateKey(privateKey: Uint8Array): Boolean + fun isValidPrivateKey(privateKey: String): Boolean + fun isValidPrivateKey(privateKey: Any): Boolean + var randomPrivateKey: () -> Uint8Array +} + +external interface `T$5` { + var create: (hash: Any) -> Any + var CURVE:`T$2` + var getPublicKey: (privateKey: dynamic /* Uint8Array | String | Any */, isCompressed: Boolean?) -> Uint8Array + var getSharedSecret: (privateA: dynamic /* Uint8Array | String | Any */, publicB: dynamic /* Uint8Array | String */, isCompressed: Boolean?) -> Uint8Array + var sign: (msgHash: dynamic /* Uint8Array | String */, privKey: dynamic /* Uint8Array | String | Any */, opts: Any?) -> Any + var verify: (signature: dynamic /* Uint8Array | String | `T$3` */, msgHash: dynamic /* Uint8Array | String */, publicKey: dynamic /* Uint8Array | String */, opts: Any?) -> Boolean + var ProjectivePoint: Any + var Signature: Any + var utils: `T$4` +} + + +external var secp256k1: `T$5` \ No newline at end of file diff --git a/base-asymmetric-encryption/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTests.kt b/cryptography/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTests.kt similarity index 100% rename from base-asymmetric-encryption/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTests.kt rename to cryptography/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPairTests.kt diff --git a/base-asymmetric-encryption/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519Tests.kt b/cryptography/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519Tests.kt similarity index 100% rename from base-asymmetric-encryption/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519Tests.kt rename to cryptography/src/jsTest/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519Tests.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/Mnemonic.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/derivation/MnemonicCode.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/secp256k1/Secp256k1Lib.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdKeyPair.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPrivateKey.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMEdPublicKey.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAKeyPair.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPrivateKey.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMRSAPublicKey.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519KeyPair.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PrivateKey.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/KMMX25519PublicKey.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAAsymmetricAlgorithm.kt diff --git a/base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt b/cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt similarity index 100% rename from base-asymmetric-encryption/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt rename to cryptography/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/utils/RSAKeyPairGeneration.kt diff --git a/base-asymmetric-encryption/src/nativeInterop/cinterop/IOHKCryptoKit.def b/cryptography/src/nativeInterop/cinterop/IOHKCryptoKit.def similarity index 100% rename from base-asymmetric-encryption/src/nativeInterop/cinterop/IOHKCryptoKit.def rename to cryptography/src/nativeInterop/cinterop/IOHKCryptoKit.def diff --git a/base-asymmetric-encryption/src/nativeInterop/cinterop/IOHKSecureRandomGeneration.def b/cryptography/src/nativeInterop/cinterop/IOHKSecureRandomGeneration.def similarity index 100% rename from base-asymmetric-encryption/src/nativeInterop/cinterop/IOHKSecureRandomGeneration.def rename to cryptography/src/nativeInterop/cinterop/IOHKSecureRandomGeneration.def diff --git a/base-asymmetric-encryption/src/nativeInterop/cinterop/SwiftCryptoKit.def b/cryptography/src/nativeInterop/cinterop/SwiftCryptoKit.def similarity index 100% rename from base-asymmetric-encryption/src/nativeInterop/cinterop/SwiftCryptoKit.def rename to cryptography/src/nativeInterop/cinterop/SwiftCryptoKit.def diff --git a/base-asymmetric-encryption/webpack.config.d/polyfill.js b/cryptography/webpack.config.d/polyfill.js similarity index 100% rename from base-asymmetric-encryption/webpack.config.d/polyfill.js rename to cryptography/webpack.config.d/polyfill.js diff --git a/ecdsa/build.gradle.kts b/ecdsa/build.gradle.kts deleted file mode 100644 index 7c438150f..000000000 --- a/ecdsa/build.gradle.kts +++ /dev/null @@ -1,275 +0,0 @@ -import org.gradle.internal.os.OperatingSystem -import org.jetbrains.dokka.gradle.DokkaTask -import org.jetbrains.kotlin.gradle.targets.js.webpack.KotlinWebpackOutput.Target - -val currentModuleName = "ApolloECDSA" -val os: OperatingSystem = OperatingSystem.current() - -plugins { - kotlin("multiplatform") - kotlin("native.cocoapods") - id("com.android.library") - id("org.jetbrains.dokka") -} - -kotlin { - android { - publishAllLibraryVariants() - } - jvm { - compilations.all { - kotlinOptions { - jvmTarget = "11" - } - } - testRuns["test"].executionTask.configure { - useJUnitPlatform() - } - } - if (os.isMacOsX) { - ios() -// tvos() -// watchos() -// macosX64() -// if (System.getProperty("os.arch") != "x86_64") { // M1Chip -// iosSimulatorArm64() -// tvosSimulatorArm64() -// watchosSimulatorArm64() -// macosArm64() -// } - } -// if (os.isWindows) { -// // mingwX86() // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// mingwX64() -// } - js(IR) { - this.moduleName = currentModuleName - this.binaries.library() - this.useCommonJs() - this.compilations["main"].packageJson { - this.version = rootProject.version.toString() - } - this.compilations["test"].packageJson { - this.version = rootProject.version.toString() - } - browser { - this.webpackTask { - this.output.library = currentModuleName - this.output.libraryTarget = Target.VAR - } - this.commonWebpackConfig { - this.cssSupport { - this.enabled = true - } - } - this.testTask { - if (os.isWindows) { - this.enabled = false - } - this.useKarma { - this.useChromeHeadless() - } - } - } - nodejs { - this.testTask { - if (os.isWindows) { - this.enabled = false - } - this.useKarma { - this.useChromeHeadless() - } - } - } - } - - if (os.isMacOsX) { - cocoapods { - this.summary = "ApolloECDSA is ECDSA" - this.version = rootProject.version.toString() - this.authors = "IOG" - this.ios.deploymentTarget = "13.0" - this.osx.deploymentTarget = "12.0" - this.tvos.deploymentTarget = "13.0" - this.watchos.deploymentTarget = "8.0" - framework { - this.baseName = currentModuleName - } - - pod("IOHKRSA") { - version = "1.0.0" - packageName = "IOHKRSA1" - source = path(project.file("../iOSLibs/IOHKRSA")) - } - - pod("IOHKSecureRandomGeneration") { - version = "1.0.0" - packageName = "IOHKSecureRandomGeneration2" - source = path(project.file("../iOSLibs/IOHKSecureRandomGeneration")) - } - } - } - - sourceSets { - val commonMain by getting { - dependencies { - implementation(project(":utils")) - implementation(project(":base-asymmetric-encryption")) - implementation(project(":hashing")) - } - } - val commonTest by getting { - dependencies { - implementation(kotlin("test")) - } - } - val jvmMain by getting { - dependencies { - implementation("org.bouncycastle:bcprov-jdk15on:1.68") - } - } - val jvmTest by getting - val androidMain by getting { - dependencies { - implementation("org.bouncycastle:bcprov-jdk15on:1.68") - } - } - val androidTest by getting { - dependencies { - implementation("junit:junit:4.13.2") - } - } - val jsMain by getting { - dependencies { - implementation(npm("elliptic", "6.5.4")) - implementation(npm("@types/elliptic", "6.4.14")) - - // Polyfill dependencies - implementation(npm("stream-browserify", "3.0.0")) - implementation(npm("buffer", "6.0.3")) - - implementation("org.jetbrains.kotlin-wrappers:kotlin-web:1.0.0-pre.461") - implementation("org.jetbrains.kotlin-wrappers:kotlin-node:18.11.13-pre.461") - } - } - val jsTest by getting - if (os.isMacOsX) { - val iosMain by getting - val iosTest by getting -// val tvosMain by getting -// val tvosTest by getting -// val watchosMain by getting -// val watchosTest by getting -// val macosX64Main by getting -// val macosX64Test by getting -// if (System.getProperty("os.arch") != "x86_64") { // M1Chip -// val iosSimulatorArm64Main by getting { -// this.dependsOn(iosMain) -// } -// val iosSimulatorArm64Test by getting { -// this.dependsOn(iosTest) -// } -// val tvosSimulatorArm64Main by getting { -// this.dependsOn(tvosMain) -// } -// val tvosSimulatorArm64Test by getting { -// this.dependsOn(tvosTest) -// } -// val watchosSimulatorArm64Main by getting { -// this.dependsOn(watchosMain) -// } -// val watchosSimulatorArm64Test by getting { -// this.dependsOn(watchosTest) -// } -// val macosArm64Main by getting { -// this.dependsOn(macosX64Main) -// } -// val macosArm64Test by getting { -// this.dependsOn(macosX64Test) -// } -// } - } -// if (os.isWindows) { -// // val mingwX86Main by getting // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// // val mingwX86Test by getting // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// val mingwX64Main by getting -// val mingwX64Test by getting -// } - } -} - -android { - compileSdk = 32 - sourceSets["main"].manifest.srcFile("src/androidMain/AndroidManifest.xml") - defaultConfig { - minSdk = 21 - targetSdk = 32 - } - compileOptions { - sourceCompatibility = JavaVersion.VERSION_11 - targetCompatibility = JavaVersion.VERSION_11 - } - /** - * Because Software Components will not be created automatically for Maven publishing from - * Android Gradle Plugin 8.0. To opt-in to the future behavior, set the Gradle property android. - * disableAutomaticComponentCreation=true in the `gradle.properties` file or use the new - * publishing DSL. - */ - publishing { - multipleVariants { - withSourcesJar() - withJavadocJar() - allVariants() - } - } -} - -// Dokka implementation -tasks.withType { - moduleName.set(project.name) - moduleVersion.set(rootProject.version.toString()) - description = """ - This is a Kotlin Multiplatform Library for ECDSA - """.trimIndent() - dokkaSourceSets { - // TODO: Figure out how to include files to the documentations - named("commonMain") { - includes.from("Module.md", "docs/Module.md") - } - } -} - -// afterEvaluate { -// tasks.withType { -// testLogging { -// events("passed", "skipped", "failed", "standard_out", "standard_error") -// showExceptions = true -// showStackTraces = true -// } -// } -// } - -// TODO(Investigate why the below tasks fails) -tasks.matching { - fun String.isOneOf(values: List): Boolean { - for (value in values) { - if (this == value) { - return true - } - } - return false - } - - it.name.isOneOf( - listOf( - "linkPodReleaseFrameworkIosFat", - ":linkPodReleaseFrameworkIosFat", - ":base-asymmetric-encryption:linkPodReleaseFrameworkIosFat", - "linkPodDebugFrameworkIosFat", - ":linkPodDebugFrameworkIosFat", - ":base-asymmetric-encryption:linkPodDebugFrameworkIosFat" - ) - ) -}.all { - this.enabled = false -} diff --git a/ecdsa/ecdsa.podspec b/ecdsa/ecdsa.podspec deleted file mode 100644 index 663c8fdc7..000000000 --- a/ecdsa/ecdsa.podspec +++ /dev/null @@ -1,43 +0,0 @@ -Pod::Spec.new do |spec| - spec.name = 'ecdsa' - spec.version = '1.7.0-alpha' - spec.homepage = '' - spec.source = { :http=> ''} - spec.authors = 'IOG' - spec.license = '' - spec.summary = 'ApolloECDSA is ECDSA' - spec.vendored_frameworks = 'build/cocoapods/framework/ApolloECDSA.framework' - spec.libraries = 'c++' - spec.ios.deployment_target = '13.0' - spec.osx.deployment_target = '12.0' - spec.tvos.deployment_target = '13.0' - spec.watchos.deployment_target = '8.0' - spec.dependency 'IOHKRSA', '1.0.0' - spec.dependency 'IOHKSecureRandomGeneration', '1.0.0' - - spec.pod_target_xcconfig = { - 'KOTLIN_PROJECT_PATH' => ':ecdsa', - 'PRODUCT_MODULE_NAME' => 'ApolloECDSA', - } - - spec.script_phases = [ - { - :name => 'Build ecdsa', - :execution_position => :before_compile, - :shell_path => '/bin/sh', - :script => <<-SCRIPT - if [ "YES" = "$OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED" ]; then - echo "Skipping Gradle build task invocation due to OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED environment variable set to \"YES\"" - exit 0 - fi - set -ev - REPO_ROOT="$PODS_TARGET_SRCROOT" - "$REPO_ROOT/../gradlew" -p "$REPO_ROOT" $KOTLIN_PROJECT_PATH:syncFramework \ - -Pkotlin.native.cocoapods.platform=$PLATFORM_NAME \ - -Pkotlin.native.cocoapods.archs="$ARCHS" \ - -Pkotlin.native.cocoapods.configuration="$CONFIGURATION" - SCRIPT - } - ] - -end \ No newline at end of file diff --git a/ecdsa/src/androidMain/AndroidManifest.xml b/ecdsa/src/androidMain/AndroidManifest.xml deleted file mode 100644 index 3ee55cfd8..000000000 --- a/ecdsa/src/androidMain/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/ecdsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt b/ecdsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt deleted file mode 100644 index 8fa645d39..000000000 --- a/ecdsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt +++ /dev/null @@ -1,43 +0,0 @@ -package io.iohk.atala.prism.apollo.ecdsa - -import io.iohk.atala.prism.apollo.utils.KMMECPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMECPublicKey -import org.bouncycastle.jce.provider.BouncyCastleProvider -import java.security.Signature - -actual object KMMECDSA { - private val provider = BouncyCastleProvider() - - actual fun sign( - type: ECDSAType, - data: ByteArray, - privateKey: KMMECPrivateKey - ): ByteArray { - val signatureAlgorithm = when (type) { - ECDSAType.ECDSA_SHA256 -> "SHA256withECDSA" - ECDSAType.ECDSA_SHA384 -> "SHA384withECDSA" - ECDSAType.ECDSA_SHA512 -> "SHA512withECDSA" - } - val signer = Signature.getInstance(signatureAlgorithm, provider) - signer.initSign(privateKey.nativeValue) - signer.update(data) - return signer.sign() - } - - actual fun verify( - type: ECDSAType, - data: ByteArray, - publicKey: KMMECPublicKey, - signature: ByteArray - ): Boolean { - val signatureAlgorithm = when (type) { - ECDSAType.ECDSA_SHA256 -> "SHA256withECDSA" - ECDSAType.ECDSA_SHA384 -> "SHA384withECDSA" - ECDSAType.ECDSA_SHA512 -> "SHA512withECDSA" - } - val verifier = Signature.getInstance(signatureAlgorithm, provider) - verifier.initVerify(publicKey.nativeValue) - verifier.update(data) - return verifier.verify(signature) - } -} diff --git a/ecdsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/ECDSAType.kt b/ecdsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/ECDSAType.kt deleted file mode 100644 index 95139ad2b..000000000 --- a/ecdsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/ECDSAType.kt +++ /dev/null @@ -1,7 +0,0 @@ -package io.iohk.atala.prism.apollo.ecdsa - -enum class ECDSAType { - ECDSA_SHA256, - ECDSA_SHA384, - ECDSA_SHA512 -} diff --git a/ecdsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt b/ecdsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt deleted file mode 100644 index dfd349d29..000000000 --- a/ecdsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt +++ /dev/null @@ -1,6 +0,0 @@ -package io.iohk.atala.prism.apollo.ecdsa - -expect object KMMECDSA { - fun sign(type: ECDSAType, data: ByteArray, privateKey: KMMECPrivateKey): ByteArray - fun verify(type: ECDSAType, data: ByteArray, publicKey: KMMECPublicKey, signature: ByteArray): Boolean -} diff --git a/ecdsa/src/commonTest/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSATests.kt b/ecdsa/src/commonTest/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSATests.kt deleted file mode 100644 index 13d81d896..000000000 --- a/ecdsa/src/commonTest/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSATests.kt +++ /dev/null @@ -1,141 +0,0 @@ -package io.iohk.atala.prism.apollo.ecdsa - -import io.iohk.atala.prism.apollo.utils.KMMECSecp256k1KeyPair -import io.iohk.atala.prism.apollo.utils.KMMECSecp256k1PrivateKey -import io.iohk.atala.prism.apollo.utils.decodeHex -import kotlin.test.Ignore -import kotlin.test.Test -import kotlin.test.assertFalse -import kotlin.test.assertTrue - -class KMMECDSATests { - - @Test - fun testECDSA() { - val textToSign = "Hello IOG!" - val keyPair = KMMECSecp256k1KeyPair.generateSecp256k1KeyPair() - - val signature = KMMECDSA.sign( - ECDSAType.ECDSA_SHA256, - textToSign.encodeToByteArray(), - keyPair.privateKey - ) - - assertTrue( - KMMECDSA.verify( - ECDSAType.ECDSA_SHA256, - textToSign.encodeToByteArray(), - keyPair.publicKey, - signature - ) - ) - } - - @Test - fun testSignAndVerifyText() { - val keyPair = KMMECSecp256k1KeyPair.generateSecp256k1KeyPair() - val text = "The quick brown fox jumps over the lazy dog" - - val signature = KMMECDSA.sign( - type = ECDSAType.ECDSA_SHA256, - privateKey = keyPair.privateKey, - data = text.encodeToByteArray() - ) - - assertTrue( - KMMECDSA.verify( - type = ECDSAType.ECDSA_SHA256, - data = text.encodeToByteArray(), - publicKey = keyPair.publicKey, - signature = signature - ) - ) - } - - @Test - fun testSignAndVerifyData() { - val testData = byteArrayOf(-107, 101, 68, 118, 27, 74, 29, 50, -32, 72, 47, -127, -49, 3, -8, -55, -63, -66, 46, 125) - val keyPair = KMMECSecp256k1KeyPair.generateSecp256k1KeyPair() - - val signature = KMMECDSA.sign( - type = ECDSAType.ECDSA_SHA256, - privateKey = keyPair.privateKey, - data = testData - ) - - assertTrue( - KMMECDSA.verify( - type = ECDSAType.ECDSA_SHA256, - data = testData, - publicKey = keyPair.publicKey, - signature = signature - ) - ) - } - - @Test - fun testNotVerifyWrongInput() { - val type = ECDSAType.ECDSA_SHA256 - val keyPair = KMMECSecp256k1KeyPair.generateSecp256k1KeyPair() - val wrongKeyPair = KMMECSecp256k1KeyPair.generateSecp256k1KeyPair() - - val text = "The quick brown fox jumps over the lazy dog" - val wrongText = "Wrong text" - - val signature = KMMECDSA.sign( - type = type, - privateKey = keyPair.privateKey, - data = text.encodeToByteArray() - ) - val wrongSignature = KMMECDSA.sign( - type = type, - privateKey = keyPair.privateKey, - data = wrongText.encodeToByteArray() - ) - - assertFalse( - KMMECDSA.verify( - type = type, - data = wrongText.encodeToByteArray(), - publicKey = keyPair.publicKey, - signature = signature - ) - ) - assertFalse( - KMMECDSA.verify( - type = type, - data = text.encodeToByteArray(), - publicKey = wrongKeyPair.publicKey, - signature = signature - ) - ) - assertFalse( - KMMECDSA.verify( - type = type, - data = text.encodeToByteArray(), - publicKey = keyPair.publicKey, - signature = wrongSignature - ) - ) - } - - @Test - @Ignore // Not working for JS - fun testVerifySameSignatureInAllImplementations() { - val testData = byteArrayOf(-107, 101, 68, 118, 27, 74, 29, 50, -32, 72, 47, -127, -49, 3, -8, -55, -63, -66, 46, 125) - val hexEncodedPrivateKey = "0123fbf1050c3fc060b709fdcf240e766a41190c40afc5ac7a702961df8313c0" - val hexEncodedSignature = - "30450221008a78c557dfc18275b5c800281ef8d26d2b40572b9c1442d708c610f50f797bd302207e44e340f787df7ab1299dabfc988e4c02fcaca0f68dbe813050f4b8641fa739" - val privateKey = KMMECSecp256k1PrivateKey.secp256k1FromBytes(hexEncodedPrivateKey.decodeHex()) - val signature = hexEncodedSignature.decodeHex() - - assertTrue( - KMMECDSA.verify( - type = ECDSAType.ECDSA_SHA256, - data = testData, - publicKey = privateKey.getPublicKey(), - signature = signature - ) - ) - } -} diff --git a/ecdsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt b/ecdsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt deleted file mode 100644 index ddb1bd336..000000000 --- a/ecdsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt +++ /dev/null @@ -1,115 +0,0 @@ -package io.iohk.atala.prism.apollo.ecdsa - -/* ktlint-disable */ -import io.iohk.atala.prism.apollo.hashing.SHA256 -import io.iohk.atala.prism.apollo.hashing.SHA384 -import io.iohk.atala.prism.apollo.hashing.SHA512 -import io.iohk.atala.prism.apollo.secp256k1.Secp256k1Exception -import io.iohk.atala.prism.apollo.utils.KMMECPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMECPublicKey -import io.iohk.atala.prism.apollo.utils.toHex -import kotlinx.cinterop.UByteVar -import kotlinx.cinterop.addressOf -import kotlinx.cinterop.alloc -import kotlinx.cinterop.allocArray -import kotlinx.cinterop.convert -import kotlinx.cinterop.memScoped -import kotlinx.cinterop.pin -import kotlinx.cinterop.ptr -import kotlinx.cinterop.readBytes -import secp256k1.* -/* ktlint-disable */ - -actual object KMMECDSA { - @OptIn(ExperimentalUnsignedTypes::class) - actual fun sign( - type: ECDSAType, - data: ByteArray, - privateKey: KMMECPrivateKey - ): ByteArray { - val hashedData = when (type) { - ECDSAType.ECDSA_SHA256 -> SHA256().digest(data) - ECDSAType.ECDSA_SHA384 -> SHA384().digest(data) - ECDSAType.ECDSA_SHA512 -> SHA512().digest(data) - } - memScoped { - // Context - val context = secp256k1_context_create((SECP256K1_CONTEXT_SIGN or SECP256K1_CONTEXT_VERIFY).convert()) - - val privateKeyPinned = privateKey.nativeValue.pin() - val nPrivateKey = privateKeyPinned.addressOf(0) - - val messagePinned = hashedData.toUByteArray().pin() - val nMessage = messagePinned.addressOf(0) - - val nSig = alloc() - if (secp256k1_ecdsa_sign(context, nSig.ptr, nMessage, nPrivateKey, null, null) != 1) { - throw Secp256k1Exception("secp256k1_ecdsa_sign() failed") - } - val natOutput = allocArray(64) - - if(secp256k1_ecdsa_signature_serialize_compact(context, natOutput, nSig.ptr) != 1) { - throw Secp256k1Exception("secp256k1_ecdsa_signature_serialize_compact() failed") - } - - this.defer { - secp256k1_context_destroy(context) - privateKeyPinned.unpin() - messagePinned.unpin() - } - return natOutput.readBytes(64) - } - } - - @OptIn(ExperimentalUnsignedTypes::class) - actual fun verify( - type: ECDSAType, - data: ByteArray, - publicKey: KMMECPublicKey, - signature: ByteArray - ): Boolean { - val hashedData = when (type) { - ECDSAType.ECDSA_SHA256 -> SHA256().digest(data) - ECDSAType.ECDSA_SHA384 -> SHA384().digest(data) - ECDSAType.ECDSA_SHA512 -> SHA512().digest(data) - } - memScoped { - // Context - val context = secp256k1_context_create((SECP256K1_CONTEXT_SIGN or SECP256K1_CONTEXT_VERIFY).convert()) - - // Public Key Alloc - val publicKeyPinned = publicKey.getEncoded().asUByteArray().pin() - val natPub = publicKeyPinned.addressOf(0) - val nPublicKey = alloc() - - if (secp256k1_ec_pubkey_parse(context, nPublicKey.ptr, natPub, publicKey.nativeValue.size.convert()) != 1) { - throw Secp256k1Exception("secp256k1_ec_pubkey_parse() failed") - } - - // Message - val messagePinned = hashedData.toUByteArray().pin() - val nMessage = messagePinned.addressOf(0) - - // Signature - val sig = alloc() - val sigPinned = signature.toUByteArray().pin() - val nativeBytes = sigPinned.addressOf(0) - val result = when { - signature.size == 64 -> secp256k1_ecdsa_signature_parse_compact(context, sig.ptr, nativeBytes) - signature.size < 64 -> throw Secp256k1Exception("Unknown signature format") - else -> secp256k1_ecdsa_signature_parse_der(context, sig.ptr, nativeBytes, signature.size.convert()) - } - if (result != 1) { - throw Secp256k1Exception("cannot parse signature (size = ${signature.size} sig = ${signature.toHex()}") - } - - this.defer { - secp256k1_context_destroy(context) - publicKeyPinned.unpin() - messagePinned.unpin() - sigPinned.unpin() - } - return secp256k1_ecdsa_verify(context, sig.ptr, nMessage, nPublicKey.ptr) == 1 - } - } -} diff --git a/ecdsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt b/ecdsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt deleted file mode 100644 index 0928f4cfe..000000000 --- a/ecdsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt +++ /dev/null @@ -1,47 +0,0 @@ -package io.iohk.atala.prism.apollo.ecdsa - -import io.iohk.atala.prism.apollo.hashing.internal.toHexString -import io.iohk.atala.prism.apollo.utils.ECConfig -import io.iohk.atala.prism.apollo.utils.KMMECPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMECPublicKey -import io.iohk.atala.prism.apollo.utils.decodeHex -import io.iohk.atala.prism.apollo.utils.external.ec - -actual object KMMECDSA { - actual fun sign( - type: ECDSAType, - data: ByteArray, - privateKey: KMMECPrivateKey - ): ByteArray { - when (type) { - ECDSAType.ECDSA_SHA256 -> {} - ECDSAType.ECDSA_SHA384, ECDSAType.ECDSA_SHA512 -> { - throw NotImplementedError("Only ECDSA with SHA256 is supported") - } - } - val byteList = privateKey.nativeValue.toArray().map { it.toByte() } - val padding = ByteArray(ECConfig.PRIVATE_KEY_BYTE_SIZE - byteList.size) { 0 } - val privateKeyBytes = (padding + byteList).toHexString() - - val ecjs = ec("secp256k1") - val signature = ecjs.sign(data.toHexString(), privateKeyBytes, enc = "hex") - val value = signature.toDER(enc = "hex").unsafeCast() - return value.decodeHex() - } - - actual fun verify( - type: ECDSAType, - data: ByteArray, - publicKey: KMMECPublicKey, - signature: ByteArray - ): Boolean { - when (type) { - ECDSAType.ECDSA_SHA256 -> {} - ECDSAType.ECDSA_SHA384, ECDSAType.ECDSA_SHA512 -> { - throw NotImplementedError("Only ECDSA with SHA256 is supported") - } - } - val ecjs = ec("secp256k1") - return ecjs.verify(data.toHexString(), signature.toHexString(), publicKey.getEncoded().toHexString(), enc = "hex") - } -} diff --git a/ecdsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt b/ecdsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt deleted file mode 100644 index 8fa645d39..000000000 --- a/ecdsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/ecdsa/KMMECDSA.kt +++ /dev/null @@ -1,43 +0,0 @@ -package io.iohk.atala.prism.apollo.ecdsa - -import io.iohk.atala.prism.apollo.utils.KMMECPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMECPublicKey -import org.bouncycastle.jce.provider.BouncyCastleProvider -import java.security.Signature - -actual object KMMECDSA { - private val provider = BouncyCastleProvider() - - actual fun sign( - type: ECDSAType, - data: ByteArray, - privateKey: KMMECPrivateKey - ): ByteArray { - val signatureAlgorithm = when (type) { - ECDSAType.ECDSA_SHA256 -> "SHA256withECDSA" - ECDSAType.ECDSA_SHA384 -> "SHA384withECDSA" - ECDSAType.ECDSA_SHA512 -> "SHA512withECDSA" - } - val signer = Signature.getInstance(signatureAlgorithm, provider) - signer.initSign(privateKey.nativeValue) - signer.update(data) - return signer.sign() - } - - actual fun verify( - type: ECDSAType, - data: ByteArray, - publicKey: KMMECPublicKey, - signature: ByteArray - ): Boolean { - val signatureAlgorithm = when (type) { - ECDSAType.ECDSA_SHA256 -> "SHA256withECDSA" - ECDSAType.ECDSA_SHA384 -> "SHA384withECDSA" - ECDSAType.ECDSA_SHA512 -> "SHA512withECDSA" - } - val verifier = Signature.getInstance(signatureAlgorithm, provider) - verifier.initVerify(publicKey.nativeValue) - verifier.update(data) - return verifier.verify(signature) - } -} diff --git a/jose/build.gradle.kts b/jose/build.gradle.kts deleted file mode 100644 index ac7d0a97e..000000000 --- a/jose/build.gradle.kts +++ /dev/null @@ -1,219 +0,0 @@ -import org.gradle.internal.os.OperatingSystem -import org.jetbrains.dokka.gradle.DokkaTask - -val currentModuleName = "JOSE" -val os: OperatingSystem = OperatingSystem.current() - -plugins { - kotlin("multiplatform") - kotlin("native.cocoapods") - id("com.android.library") - id("org.jetbrains.dokka") -} - -kotlin { - android { - publishAllLibraryVariants() - } - jvm { - compilations.all { - kotlinOptions { - jvmTarget = "11" - } - } - testRuns["test"].executionTask.configure { - useJUnitPlatform() - } - } - if (os.isMacOsX) { - // ios() -// tvos() -// watchos() -// macosX64() -// if (System.getProperty("os.arch") != "x86_64") { // M1Chip -// iosSimulatorArm64() -// tvosSimulatorArm64() -// watchosSimulatorArm64() -// macosArm64() -// } - } -// if (os.isWindows) { -// // mingwX86() // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// mingwX64() -// } -// js(IR) { -// this.moduleName = currentModuleName -// this.binaries.library() -// this.useCommonJs() -// this.compilations["main"].packageJson { -// this.version = rootProject.version.toString() -// } -// this.compilations["test"].packageJson { -// this.version = rootProject.version.toString() -// } -// browser { -// this.webpackTask { -// this.output.library = currentModuleName -// this.output.libraryTarget = Target.VAR -// } -// this.commonWebpackConfig { -// this.cssSupport { -// this.enabled = true -// } -// } -// this.testTask { -// if (os.isWindows) { -// this.enabled = false -// } -// this.useKarma { -// this.useChromeHeadless() -// } -// } -// } -// nodejs { -// this.testTask { -// if (os.isWindows) { -// this.enabled = false -// } -// this.useKarma { -// this.useChromeHeadless() -// } -// } -// } -// } - - if (os.isMacOsX) { - cocoapods { - this.summary = "JOSE is JSON Object Signing and Encryption" - this.version = rootProject.version.toString() - this.authors = "IOG" - this.ios.deploymentTarget = "13.0" - this.osx.deploymentTarget = "12.0" - this.tvos.deploymentTarget = "13.0" - this.watchos.deploymentTarget = "8.0" - framework { - this.baseName = currentModuleName - } - } - } - - sourceSets { - val commonMain by getting - val commonTest by getting { - dependencies { - implementation(kotlin("test")) - } - } - val jvmMain by getting { - dependencies { - implementation("com.nimbusds:nimbus-jose-jwt:9.31") - } - } - val jvmTest by getting - val androidMain by getting { - dependencies { - implementation("com.nimbusds:nimbus-jose-jwt:9.31") - } - } - val androidTest by getting { - dependencies { - implementation("junit:junit:4.13.2") - } - } -// val jsMain by getting -// val jsTest by getting - if (os.isMacOsX) { -// val iosMain by getting -// val iosTest by getting -// val tvosMain by getting -// val tvosTest by getting -// val watchosMain by getting -// val watchosTest by getting -// val macosX64Main by getting -// val macosX64Test by getting - if (System.getProperty("os.arch") != "x86_64") { // M1Chip -// val iosSimulatorArm64Main by getting { -// this.dependsOn(iosMain) -// } -// val iosSimulatorArm64Test by getting { -// this.dependsOn(iosTest) -// } -// val tvosSimulatorArm64Main by getting { -// this.dependsOn(tvosMain) -// } -// val tvosSimulatorArm64Test by getting { -// this.dependsOn(tvosTest) -// } -// val watchosSimulatorArm64Main by getting { -// this.dependsOn(watchosMain) -// } -// val watchosSimulatorArm64Test by getting { -// this.dependsOn(watchosTest) -// } -// val macosArm64Main by getting { -// this.dependsOn(macosX64Main) -// } -// val macosArm64Test by getting { -// this.dependsOn(macosX64Test) -// } - } - } -// if (os.isWindows) { -// // val mingwX86Main by getting // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// // val mingwX86Test by getting // it depend on kotlinx-datetime lib to support this platform before we can support it as well -// val mingwX64Main by getting -// val mingwX64Test by getting -// } - } -} - -android { - compileSdk = 32 - sourceSets["main"].manifest.srcFile("src/androidMain/AndroidManifest.xml") - defaultConfig { - minSdk = 21 - targetSdk = 32 - } - compileOptions { - sourceCompatibility = JavaVersion.VERSION_11 - targetCompatibility = JavaVersion.VERSION_11 - } - /** - * Because Software Components will not be created automatically for Maven publishing from - * Android Gradle Plugin 8.0. To opt-in to the future behavior, set the Gradle property android. - * disableAutomaticComponentCreation=true in the `gradle.properties` file or use the new - * publishing DSL. - */ - publishing { - multipleVariants { - withSourcesJar() - withJavadocJar() - allVariants() - } - } -} - -// Dokka implementation -tasks.withType { - moduleName.set(project.name) - moduleVersion.set(rootProject.version.toString()) - description = """ - This is a Kotlin Multiplatform Library for JOSE - JSON Object Signing and Encryption - """.trimIndent() - dokkaSourceSets { - // TODO: Figure out how to include files to the documentations - named("commonMain") { - includes.from("Module.md", "docs/Module.md") - } - } -} - -// afterEvaluate { -// tasks.withType { -// testLogging { -// events("passed", "skipped", "failed", "standard_out", "standard_error") -// showExceptions = true -// showStackTraces = true -// } -// } -// } diff --git a/jose/jose.podspec b/jose/jose.podspec deleted file mode 100644 index 02a6fa529..000000000 --- a/jose/jose.podspec +++ /dev/null @@ -1,42 +0,0 @@ -Pod::Spec.new do |spec| - spec.name = 'jose' - spec.version = '1.7.0-alpha' - spec.homepage = '' - spec.source = { :http=> ''} - spec.authors = 'IOG' - spec.license = '' - spec.summary = 'JOSE is JSON Object Signing and Encryption' - spec.vendored_frameworks = 'build/cocoapods/framework/jose.framework' - spec.libraries = 'c++' - spec.ios.deployment_target = '13.0' - spec.osx.deployment_target = '12.0' - spec.tvos.deployment_target = '13.0' - spec.watchos.deployment_target = '8.0' - - - spec.pod_target_xcconfig = { - 'KOTLIN_PROJECT_PATH' => ':jose', - 'PRODUCT_MODULE_NAME' => 'jose', - } - - spec.script_phases = [ - { - :name => 'Build jose', - :execution_position => :before_compile, - :shell_path => '/bin/sh', - :script => <<-SCRIPT - if [ "YES" = "$OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED" ]; then - echo "Skipping Gradle build task invocation due to OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED environment variable set to \"YES\"" - exit 0 - fi - set -ev - REPO_ROOT="$PODS_TARGET_SRCROOT" - "$REPO_ROOT/../gradlew" -p "$REPO_ROOT" $KOTLIN_PROJECT_PATH:syncFramework \ - -Pkotlin.native.cocoapods.platform=$PLATFORM_NAME \ - -Pkotlin.native.cocoapods.archs="$ARCHS" \ - -Pkotlin.native.cocoapods.configuration="$CONFIGURATION" - SCRIPT - } - ] - -end \ No newline at end of file diff --git a/jose/src/androidMain/AndroidManifest.xml b/jose/src/androidMain/AndroidManifest.xml deleted file mode 100644 index 09bb0c772..000000000 --- a/jose/src/androidMain/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/jose/src/androidMain/kotlin/io/iohk/atala/prism/apollo/jose/JOSE.kt b/jose/src/androidMain/kotlin/io/iohk/atala/prism/apollo/jose/JOSE.kt deleted file mode 100644 index ac7648732..000000000 --- a/jose/src/androidMain/kotlin/io/iohk/atala/prism/apollo/jose/JOSE.kt +++ /dev/null @@ -1,199 +0,0 @@ -package io.iohk.atala.prism.apollo.jose - -import com.nimbusds.jose.JOSEException -import com.nimbusds.jose.JOSEObjectType -import com.nimbusds.jose.JWSAlgorithm -import com.nimbusds.jose.JWSHeader -import com.nimbusds.jose.JWSObject -import com.nimbusds.jose.JWSObjectJSON -import com.nimbusds.jose.Payload -import com.nimbusds.jose.UnprotectedHeader -import com.nimbusds.jose.crypto.ECDSASigner -import com.nimbusds.jose.crypto.ECDSAVerifier -import com.nimbusds.jose.crypto.Ed25519Signer -import com.nimbusds.jose.crypto.Ed25519Verifier -import com.nimbusds.jose.jwk.Curve -import com.nimbusds.jose.jwk.ECKey -import com.nimbusds.jose.jwk.JWK -import com.nimbusds.jose.jwk.OctetKeyPair -import com.nimbusds.jose.util.Base64URL -import com.nimbusds.jwt.JWTClaimsSet -import com.nimbusds.jwt.SignedJWT -import java.security.SignatureException - -sealed interface Key { - val id: String - val jwk: JWK - val curve: Curve -} - -enum class Typ(val typ: String) { - Encrypted("application/didcomm-encrypted+json"), - Signed("application/didcomm-signed+json"), - Plaintext("application/didcomm-plain+json"); - - companion object { - fun parse(str: String): Typ = when (str) { - "application/didcomm-encrypted+json" -> Encrypted - "application/didcomm-signed+json" -> Signed - "application/didcomm-plain+json" -> Plaintext - else -> throw IllegalArgumentException("Unsupported message typ") - } - } -} - -enum class SignAlg { - /** - * Elliptic curve digital signature with edwards curves Ed25519 and SHA-512 - */ - ED25519, - - /** - * Elliptic curve digital signature with NIST p-256 curve and SHA-256 - */ - ES256, - - /** - * Elliptic curve digital signature with Secp256k1 keys - */ - ES256K -} - -inline fun JWK.asKey(): Key { - if (this !is Key) throw IllegalArgumentException("Can not cast JWK to ${Key::class.java.name}") - return this -} - -object JWS { - fun sign(payload: String, key: Key): String { - val jwk = key.jwk - val alg = getJWSAlgorithm(jwk) - - val signer = try { - when (alg) { - JWSAlgorithm.ES256 -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.ES256K -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.EdDSA -> Ed25519Signer(jwk.asKey()) - else -> throw NotImplementedError(alg.name) - } - } catch (e: JOSEException) { - throw NotImplementedError(alg.name) - } - - val jwsProtectedHeader = JWSHeader.Builder(alg) - .type(JOSEObjectType(Typ.Signed.typ)) - .build() - - val jwsUnprotectedHeader = UnprotectedHeader.Builder().keyID(key.id).build() - return JWSObjectJSON(Payload(Base64URL.encode(payload))) - .apply { - try { - sign(jwsProtectedHeader, jwsUnprotectedHeader, signer) - } catch (e: JOSEException) { - // this can be thrown if the signature type is not supported - // example: curve256k1 is not supported in JDK >= 15 - if (e.cause is SignatureException) { - throw NotImplementedError("Unsupported signature algorithm ${e.cause}") - } - throw NotImplementedError("JWS cannot be signed $e") - } - } - .serializeGeneral() - } - - fun verify(signature: JWSObjectJSON.Signature, signAlg: SignAlg, key: Key) { - val jwk = key.jwk - - val verifier = try { - when (signAlg) { - SignAlg.ES256 -> ECDSAVerifier(jwk.asKey()) - SignAlg.ES256K -> ECDSAVerifier(jwk.asKey()) - SignAlg.ED25519 -> Ed25519Verifier(jwk.asKey()) - } - } catch (e: JOSEException) { - throw NotImplementedError(signAlg.name) - } - - try { - if (!signature.verify(verifier)) { - throw NotImplementedError("Invalid signature") - } - } catch (e: JOSEException) { - // this can be thrown if the signature type is not supported - // example: curve256k1 is not supported in JDK >= 15 - if (e.cause is SignatureException) { - throw NotImplementedError("Unsupported signature algorithm ${e.cause}") - } - throw NotImplementedError("JWS signature cannot be verified $e") - } - } -} - -object JWT { - fun sign(jwtClaimsSet: JWTClaimsSet, key: Key): String { - val jwk = key.jwk - val alg = getJWSAlgorithm(jwk) - - val signer = try { - when (alg) { - JWSAlgorithm.ES256 -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.ES256K -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.EdDSA -> Ed25519Signer(jwk.asKey()) - else -> throw NotImplementedError(alg.name) - } - } catch (e: JOSEException) { - throw NotImplementedError(alg.name) - } - - val jwsHeader = JWSHeader.Builder(alg) - .keyID(key.id) - .build() - - return SignedJWT(jwsHeader, jwtClaimsSet).apply { - try { - sign(signer) - } catch (e: JOSEException) { - throw NotImplementedError("JWT cannot be signed $e") - } - }.serialize() - } -} - -private fun getCryptoAlg(signature: JWSObjectJSON.Signature): SignAlg { - return when (val alg = signature.header.algorithm) { - JWSAlgorithm.ES256 -> SignAlg.ES256 - JWSAlgorithm.ES256K -> SignAlg.ES256K - JWSAlgorithm.EdDSA -> SignAlg.ED25519 - else -> throw NotImplementedError("UnsupportedCurveException ${alg.name}") - } -} - -private fun getJWSAlgorithm(jwk: JWK): JWSAlgorithm { - return when (jwk) { - is ECKey -> { - when (jwk.curve) { - Curve.P_256 -> JWSAlgorithm.ES256 - Curve.SECP256K1 -> JWSAlgorithm.ES256K - else -> { - throw NotImplementedError("UnsupportedCurveException ${jwk.curve}") - } - } - } - is OctetKeyPair -> { - when (jwk.curve) { - Curve.Ed25519 -> JWSAlgorithm.EdDSA - else -> throw NotImplementedError("UnsupportedCurveException ${jwk.curve.name}") - } - } - else -> throw NotImplementedError("UnsupportedCurveException ${jwk.javaClass.name}") - } -} - -private fun getCryptoAlg(jws: JWSObject): SignAlg { - return when (val alg = jws.header.algorithm) { - JWSAlgorithm.ES256 -> SignAlg.ES256 - JWSAlgorithm.ES256K -> SignAlg.ES256K - JWSAlgorithm.EdDSA -> SignAlg.ED25519 - else -> throw NotImplementedError(alg.name) - } -} diff --git a/jose/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/jose/JOSE.kt b/jose/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/jose/JOSE.kt deleted file mode 100644 index ac7648732..000000000 --- a/jose/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/jose/JOSE.kt +++ /dev/null @@ -1,199 +0,0 @@ -package io.iohk.atala.prism.apollo.jose - -import com.nimbusds.jose.JOSEException -import com.nimbusds.jose.JOSEObjectType -import com.nimbusds.jose.JWSAlgorithm -import com.nimbusds.jose.JWSHeader -import com.nimbusds.jose.JWSObject -import com.nimbusds.jose.JWSObjectJSON -import com.nimbusds.jose.Payload -import com.nimbusds.jose.UnprotectedHeader -import com.nimbusds.jose.crypto.ECDSASigner -import com.nimbusds.jose.crypto.ECDSAVerifier -import com.nimbusds.jose.crypto.Ed25519Signer -import com.nimbusds.jose.crypto.Ed25519Verifier -import com.nimbusds.jose.jwk.Curve -import com.nimbusds.jose.jwk.ECKey -import com.nimbusds.jose.jwk.JWK -import com.nimbusds.jose.jwk.OctetKeyPair -import com.nimbusds.jose.util.Base64URL -import com.nimbusds.jwt.JWTClaimsSet -import com.nimbusds.jwt.SignedJWT -import java.security.SignatureException - -sealed interface Key { - val id: String - val jwk: JWK - val curve: Curve -} - -enum class Typ(val typ: String) { - Encrypted("application/didcomm-encrypted+json"), - Signed("application/didcomm-signed+json"), - Plaintext("application/didcomm-plain+json"); - - companion object { - fun parse(str: String): Typ = when (str) { - "application/didcomm-encrypted+json" -> Encrypted - "application/didcomm-signed+json" -> Signed - "application/didcomm-plain+json" -> Plaintext - else -> throw IllegalArgumentException("Unsupported message typ") - } - } -} - -enum class SignAlg { - /** - * Elliptic curve digital signature with edwards curves Ed25519 and SHA-512 - */ - ED25519, - - /** - * Elliptic curve digital signature with NIST p-256 curve and SHA-256 - */ - ES256, - - /** - * Elliptic curve digital signature with Secp256k1 keys - */ - ES256K -} - -inline fun JWK.asKey(): Key { - if (this !is Key) throw IllegalArgumentException("Can not cast JWK to ${Key::class.java.name}") - return this -} - -object JWS { - fun sign(payload: String, key: Key): String { - val jwk = key.jwk - val alg = getJWSAlgorithm(jwk) - - val signer = try { - when (alg) { - JWSAlgorithm.ES256 -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.ES256K -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.EdDSA -> Ed25519Signer(jwk.asKey()) - else -> throw NotImplementedError(alg.name) - } - } catch (e: JOSEException) { - throw NotImplementedError(alg.name) - } - - val jwsProtectedHeader = JWSHeader.Builder(alg) - .type(JOSEObjectType(Typ.Signed.typ)) - .build() - - val jwsUnprotectedHeader = UnprotectedHeader.Builder().keyID(key.id).build() - return JWSObjectJSON(Payload(Base64URL.encode(payload))) - .apply { - try { - sign(jwsProtectedHeader, jwsUnprotectedHeader, signer) - } catch (e: JOSEException) { - // this can be thrown if the signature type is not supported - // example: curve256k1 is not supported in JDK >= 15 - if (e.cause is SignatureException) { - throw NotImplementedError("Unsupported signature algorithm ${e.cause}") - } - throw NotImplementedError("JWS cannot be signed $e") - } - } - .serializeGeneral() - } - - fun verify(signature: JWSObjectJSON.Signature, signAlg: SignAlg, key: Key) { - val jwk = key.jwk - - val verifier = try { - when (signAlg) { - SignAlg.ES256 -> ECDSAVerifier(jwk.asKey()) - SignAlg.ES256K -> ECDSAVerifier(jwk.asKey()) - SignAlg.ED25519 -> Ed25519Verifier(jwk.asKey()) - } - } catch (e: JOSEException) { - throw NotImplementedError(signAlg.name) - } - - try { - if (!signature.verify(verifier)) { - throw NotImplementedError("Invalid signature") - } - } catch (e: JOSEException) { - // this can be thrown if the signature type is not supported - // example: curve256k1 is not supported in JDK >= 15 - if (e.cause is SignatureException) { - throw NotImplementedError("Unsupported signature algorithm ${e.cause}") - } - throw NotImplementedError("JWS signature cannot be verified $e") - } - } -} - -object JWT { - fun sign(jwtClaimsSet: JWTClaimsSet, key: Key): String { - val jwk = key.jwk - val alg = getJWSAlgorithm(jwk) - - val signer = try { - when (alg) { - JWSAlgorithm.ES256 -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.ES256K -> ECDSASigner(jwk.asKey()) - JWSAlgorithm.EdDSA -> Ed25519Signer(jwk.asKey()) - else -> throw NotImplementedError(alg.name) - } - } catch (e: JOSEException) { - throw NotImplementedError(alg.name) - } - - val jwsHeader = JWSHeader.Builder(alg) - .keyID(key.id) - .build() - - return SignedJWT(jwsHeader, jwtClaimsSet).apply { - try { - sign(signer) - } catch (e: JOSEException) { - throw NotImplementedError("JWT cannot be signed $e") - } - }.serialize() - } -} - -private fun getCryptoAlg(signature: JWSObjectJSON.Signature): SignAlg { - return when (val alg = signature.header.algorithm) { - JWSAlgorithm.ES256 -> SignAlg.ES256 - JWSAlgorithm.ES256K -> SignAlg.ES256K - JWSAlgorithm.EdDSA -> SignAlg.ED25519 - else -> throw NotImplementedError("UnsupportedCurveException ${alg.name}") - } -} - -private fun getJWSAlgorithm(jwk: JWK): JWSAlgorithm { - return when (jwk) { - is ECKey -> { - when (jwk.curve) { - Curve.P_256 -> JWSAlgorithm.ES256 - Curve.SECP256K1 -> JWSAlgorithm.ES256K - else -> { - throw NotImplementedError("UnsupportedCurveException ${jwk.curve}") - } - } - } - is OctetKeyPair -> { - when (jwk.curve) { - Curve.Ed25519 -> JWSAlgorithm.EdDSA - else -> throw NotImplementedError("UnsupportedCurveException ${jwk.curve.name}") - } - } - else -> throw NotImplementedError("UnsupportedCurveException ${jwk.javaClass.name}") - } -} - -private fun getCryptoAlg(jws: JWSObject): SignAlg { - return when (val alg = jws.header.algorithm) { - JWSAlgorithm.ES256 -> SignAlg.ES256 - JWSAlgorithm.ES256K -> SignAlg.ES256K - JWSAlgorithm.EdDSA -> SignAlg.ED25519 - else -> throw NotImplementedError(alg.name) - } -} diff --git a/rsa/README.md b/rsa/README.md deleted file mode 100644 index c77fce15f..000000000 --- a/rsa/README.md +++ /dev/null @@ -1,41 +0,0 @@ -# Apollo - AES - -[![Kotlin](https://img.shields.io/badge/kotlin-1.7.21-blue.svg?logo=kotlin)](http://kotlinlang.org) - -![android](https://camo.githubusercontent.com/b1d9ad56ab51c4ad1417e9a5ad2a8fe63bcc4755e584ec7defef83755c23f923/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d616e64726f69642d3645444238442e7376673f7374796c653d666c6174) -![apple-silicon](https://camo.githubusercontent.com/a92c841ffd377756a144d5723ff04ecec886953d40ac03baa738590514714921/687474703a2f2f696d672e736869656c64732e696f2f62616467652f737570706f72742d2535424170706c6553696c69636f6e2535442d3433424246462e7376673f7374796c653d666c6174) -![ios](https://camo.githubusercontent.com/1fec6f0d044c5e1d73656bfceed9a78fd4121b17e82a2705d2a47f6fd1f0e3e5/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d696f732d4344434443442e7376673f7374796c653d666c6174) -![jvm](https://camo.githubusercontent.com/700f5dcd442fd835875568c038ae5cd53518c80ae5a0cf12c7c5cf4743b5225b/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6a766d2d4442343133442e7376673f7374796c653d666c6174) -![js](https://camo.githubusercontent.com/3e0a143e39915184b54b60a2ecedec75e801f396d34b5b366c94ec3604f7e6bd/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6a732d4638444235442e7376673f7374796c653d666c6174) -![getNode-js](https://camo.githubusercontent.com/d08fda729ceebcae0f23c83499ca8f06105350f037661ac9a4cc7f58edfdbca9/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6e6f64656a732d3638613036332e7376673f7374796c653d666c6174) -![macos](https://camo.githubusercontent.com/1b8313498db244646b38a4480186ae2b25464e5e8d71a1920c52b2be5212b909/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d6d61636f732d3131313131312e7376673f7374796c653d666c6174) -![tvos](https://camo.githubusercontent.com/4ac08d7fb1bcb8ef26388cd2bf53b49626e1ab7cbda581162a946dd43e6a2726/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d74766f732d3830383038302e7376673f7374796c653d666c6174) -![watchos](https://camo.githubusercontent.com/135dbadae40f9cabe7a3a040f9380fb485cff36c90909f3c1ae36b81c304426b/687474703a2f2f696d672e736869656c64732e696f2f62616467652f706c6174666f726d2d77617463686f732d4330433043302e7376673f7374796c653d666c6174) - -Apollo RSA is Kotlin Multiplatform library for RSA & RSA/PSS signature. - -## Supported Key Size - -- 1024 -- 2048 -- 3072 -- 4096 - -## Supported Signature - -- RSA -- RSA/PSS - -## Usage - -Example of key pair generation, signing and verifying RSA/PSS with SHA256 -```kotlin -val keyPair = KMMKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, 2048) -val rsa = RSA() -val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) -val verify = rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256) -``` - -## TODO - -* Make support for key size depend on the logic of multiable of 1024 instead of the current limited value selection diff --git a/rsa/rsa.podspec b/rsa/rsa.podspec deleted file mode 100644 index 804b15835..000000000 --- a/rsa/rsa.podspec +++ /dev/null @@ -1,42 +0,0 @@ -Pod::Spec.new do |spec| - spec.name = 'rsa' - spec.version = '1.7.0-alpha' - spec.homepage = '' - spec.source = { :http=> ''} - spec.authors = 'IOG' - spec.license = '' - spec.summary = 'ApolloRSA is an RSA lib' - spec.vendored_frameworks = 'build/cocoapods/framework/ApolloRSA.framework' - spec.libraries = 'c++' - spec.ios.deployment_target = '13.0' - spec.osx.deployment_target = '12.0' - spec.tvos.deployment_target = '13.0' - spec.watchos.deployment_target = '8.0' - spec.dependency 'IOHKRSA', '1.0.0' - - spec.pod_target_xcconfig = { - 'KOTLIN_PROJECT_PATH' => ':rsa', - 'PRODUCT_MODULE_NAME' => 'ApolloRSA', - } - - spec.script_phases = [ - { - :name => 'Build rsa', - :execution_position => :before_compile, - :shell_path => '/bin/sh', - :script => <<-SCRIPT - if [ "YES" = "$OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED" ]; then - echo "Skipping Gradle build task invocation due to OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED environment variable set to \"YES\"" - exit 0 - fi - set -ev - REPO_ROOT="$PODS_TARGET_SRCROOT" - "$REPO_ROOT/../gradlew" -p "$REPO_ROOT" $KOTLIN_PROJECT_PATH:syncFramework \ - -Pkotlin.native.cocoapods.platform=$PLATFORM_NAME \ - -Pkotlin.native.cocoapods.archs="$ARCHS" \ - -Pkotlin.native.cocoapods.configuration="$CONFIGURATION" - SCRIPT - } - ] - -end \ No newline at end of file diff --git a/rsa/src/androidAndroidTest/AndroidManifest.xml b/rsa/src/androidAndroidTest/AndroidManifest.xml deleted file mode 100644 index 71a1eb3ee..000000000 --- a/rsa/src/androidAndroidTest/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/rsa/src/androidAndroidTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt b/rsa/src/androidAndroidTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt deleted file mode 100644 index ce115cb04..000000000 --- a/rsa/src/androidAndroidTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt +++ /dev/null @@ -1,31 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAKeyPair -import io.iohk.atala.prism.apollo.utils.RSAAsymmetricAlgorithm -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.runTest -import org.junit.Test -import kotlin.test.assertTrue - -@OptIn(ExperimentalCoroutinesApi::class) -actual class RSATests { - @Test - actual fun testRSA() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSA, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSASHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSASHA256)) - } - - @Test - actual fun testRSAPSS() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256)) - } -} diff --git a/rsa/src/androidMain/AndroidManifest.xml b/rsa/src/androidMain/AndroidManifest.xml deleted file mode 100644 index 71a1eb3ee..000000000 --- a/rsa/src/androidMain/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - \ No newline at end of file diff --git a/rsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt b/rsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt deleted file mode 100644 index f17909c96..000000000 --- a/rsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt +++ /dev/null @@ -1,29 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMRSAPublicKey -import org.bouncycastle.jce.provider.BouncyCastleProvider -import java.security.Security -import java.security.Signature - -actual final class RSA : RSASigner, RSAVerifier { - - init { - Security.removeProvider("BC") - Security.addProvider(BouncyCastleProvider()) - } - - override suspend fun sign(privateKey: KMMRSAPrivateKey, data: ByteArray, type: RSASignatureType): ByteArray { - val signature = Signature.getInstance(type.nativeValue()) - signature.initSign(privateKey.nativeType) - signature.update(data) - return signature.sign() - } - - override suspend fun verify(publicKey: KMMRSAPublicKey, data: ByteArray, signedData: ByteArray, type: RSASignatureType): Boolean { - val signature = Signature.getInstance(type.nativeValue()) - signature.initVerify(publicKey.nativeType) - signature.update(data) - return signature.verify(signedData) - } -} diff --git a/rsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt b/rsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt deleted file mode 100644 index f0f01128c..000000000 --- a/rsa/src/androidMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt +++ /dev/null @@ -1,25 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual typealias RSASignatureTypeNativeType = String - -actual final enum class RSASignatureType : NativeTypeInterface { - RSASHA256, - RSASHA384, - RSASHA512, - RSAPSSSHA256, - RSAPSSSHA384, - RSAPSSSHA512; - - override fun nativeValue(): String { - return when (this) { - RSASHA256 -> "SHA256withRSA" - RSASHA384 -> "SHA384withRSA" - RSASHA512 -> "SHA512withRSA" - RSAPSSSHA256 -> "SHA256withRSA/PSS" - RSAPSSSHA384 -> "SHA384withRSA/PSS" - RSAPSSSHA512 -> "SHA512withRSA/PSS" - } - } -} diff --git a/rsa/src/androidTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt b/rsa/src/androidTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt deleted file mode 100644 index ce115cb04..000000000 --- a/rsa/src/androidTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt +++ /dev/null @@ -1,31 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAKeyPair -import io.iohk.atala.prism.apollo.utils.RSAAsymmetricAlgorithm -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.runTest -import org.junit.Test -import kotlin.test.assertTrue - -@OptIn(ExperimentalCoroutinesApi::class) -actual class RSATests { - @Test - actual fun testRSA() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSA, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSASHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSASHA256)) - } - - @Test - actual fun testRSAPSS() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256)) - } -} diff --git a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt b/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt deleted file mode 100644 index 708cd98d6..000000000 --- a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt +++ /dev/null @@ -1,3 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -expect final class RSA : RSASigner, RSAVerifier diff --git a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt b/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt deleted file mode 100644 index 67f270bfb..000000000 --- a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt +++ /dev/null @@ -1,14 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -expect class RSASignatureTypeNativeType - -expect final enum class RSASignatureType : NativeTypeInterface { - RSASHA256, - RSASHA384, - RSASHA512, - RSAPSSSHA256, - RSAPSSSHA384, - RSAPSSSHA512; -} diff --git a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASigner.kt b/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASigner.kt deleted file mode 100644 index 9a12b53c3..000000000 --- a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASigner.kt +++ /dev/null @@ -1,15 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAPrivateKey - -interface RSASigner { - /** - * Returns the signature bytes of all the data updated. The format of the signature depends on the underlying - * signature scheme. - * - * @param privateKey private key in PKCS#8 pem format - * @param data the data to sign - * @return the signature bytes of the signing operation's result. - */ - suspend fun sign(privateKey: KMMRSAPrivateKey, data: ByteArray, type: RSASignatureType): ByteArray -} diff --git a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSAVerifier.kt b/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSAVerifier.kt deleted file mode 100644 index 363266a0d..000000000 --- a/rsa/src/commonMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSAVerifier.kt +++ /dev/null @@ -1,15 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAPublicKey - -interface RSAVerifier { - /** - * Verifies the passed-in signature. - * - * @param publicKey public key in PKCS#8 pem format - * @param data data that we need to sign - * @param signedData data that has already been signed - * @return boolean value representing if the verifying was correct or not - */ - suspend fun verify(publicKey: KMMRSAPublicKey, data: ByteArray, signedData: ByteArray, type: RSASignatureType): Boolean -} diff --git a/rsa/src/commonTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt b/rsa/src/commonTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt deleted file mode 100644 index 83fecaa0b..000000000 --- a/rsa/src/commonTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt +++ /dev/null @@ -1,10 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.TestResult - -@OptIn(ExperimentalCoroutinesApi::class) -expect class RSATests { - fun testRSA(): TestResult - fun testRSAPSS(): TestResult -} diff --git a/rsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt b/rsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt deleted file mode 100644 index cca55373d..000000000 --- a/rsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt +++ /dev/null @@ -1,26 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import cocoapods.IOHKRSA.IOHKRSA -import io.iohk.atala.prism.apollo.utils.KMMRSAPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMRSAPublicKey -import io.iohk.atala.prism.apollo.utils.toByteArray -import io.iohk.atala.prism.apollo.utils.toNSData - -actual final class RSA : RSASigner, RSAVerifier { - override suspend fun sign(privateKey: KMMRSAPrivateKey, data: ByteArray, type: RSASignatureType): ByteArray { - return IOHKRSA.signRSAWithKey( - privateKey.nativeType, - type.nativeValue(), - data.toNSData() - )!!.toByteArray() - } - - override suspend fun verify(publicKey: KMMRSAPublicKey, data: ByteArray, signedData: ByteArray, type: RSASignatureType): Boolean { - return IOHKRSA.verifyRSAWithKey( - publicKey.nativeType, - type.nativeValue(), - data.toNSData(), - signedData.toNSData() - ) - } -} diff --git a/rsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt b/rsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt deleted file mode 100644 index b2652656f..000000000 --- a/rsa/src/iosMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt +++ /dev/null @@ -1,32 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import cocoapods.IOHKRSA.RSASignatureMessageType -import cocoapods.IOHKRSA.RSASignatureMessageTypeRsaPSSSHA256 -import cocoapods.IOHKRSA.RSASignatureMessageTypeRsaPSSSHA384 -import cocoapods.IOHKRSA.RSASignatureMessageTypeRsaPSSSHA512 -import cocoapods.IOHKRSA.RSASignatureMessageTypeRsaSHA256 -import cocoapods.IOHKRSA.RSASignatureMessageTypeRsaSHA384 -import cocoapods.IOHKRSA.RSASignatureMessageTypeRsaSHA512 -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual typealias RSASignatureTypeNativeType = Long - -actual final enum class RSASignatureType : NativeTypeInterface { - RSASHA256, - RSASHA384, - RSASHA512, - RSAPSSSHA256, - RSAPSSSHA384, - RSAPSSSHA512; - - override fun nativeValue(): RSASignatureMessageType { - return when (this) { - RSASHA256 -> RSASignatureMessageTypeRsaSHA256 - RSASHA384 -> RSASignatureMessageTypeRsaSHA384 - RSASHA512 -> RSASignatureMessageTypeRsaSHA512 - RSAPSSSHA256 -> RSASignatureMessageTypeRsaPSSSHA256 - RSAPSSSHA384 -> RSASignatureMessageTypeRsaPSSSHA384 - RSAPSSSHA512 -> RSASignatureMessageTypeRsaPSSSHA512 - } - } -} diff --git a/rsa/src/iosTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt b/rsa/src/iosTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt deleted file mode 100644 index ecadb4656..000000000 --- a/rsa/src/iosTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt +++ /dev/null @@ -1,31 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAKeyPair -import io.iohk.atala.prism.apollo.utils.RSAAsymmetricAlgorithm -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.runTest -import kotlin.test.Test -import kotlin.test.assertTrue - -@OptIn(ExperimentalCoroutinesApi::class) -actual class RSATests { - @Test - actual fun testRSA() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256)) - } - - @Test - actual fun testRSAPSS() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256)) - } -} diff --git a/rsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt b/rsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt deleted file mode 100644 index d2bff71cf..000000000 --- a/rsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt +++ /dev/null @@ -1,67 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMRSAPublicKey -import io.iohk.atala.prism.apollo.utils.toArrayBuffer -import io.iohk.atala.prism.apollo.utils.toByteArray -import kotlinx.coroutines.MainScope -import kotlinx.coroutines.await -import kotlinx.coroutines.promise -import web.crypto.RsaPssParams -import web.crypto.crypto - -actual final class RSA : RSASigner, RSAVerifier { - - private fun getRsaPssParams(): RsaPssParams { - val algorithm = "RSA-PSS" - return js("{name: algorithm, saltLength: 32}") as RsaPssParams - } - - override suspend fun sign(privateKey: KMMRSAPrivateKey, data: ByteArray, type: RSASignatureType): ByteArray { - return when (type) { - RSASignatureType.RSASHA256, RSASignatureType.RSASHA384, RSASignatureType.RSASHA512 -> { - MainScope().promise { - crypto.subtle.sign( - privateKey.nativeType.algorithm.name, - privateKey.nativeType, - data.toArrayBuffer() - ).await().toByteArray() - }.await() - } - RSASignatureType.RSAPSSSHA256, RSASignatureType.RSAPSSSHA384, RSASignatureType.RSAPSSSHA512 -> { - MainScope().promise { - crypto.subtle.sign( - getRsaPssParams(), - privateKey.nativeType, - data.toArrayBuffer() - ).await().toByteArray() - }.await() - } - } - } - - override suspend fun verify(publicKey: KMMRSAPublicKey, data: ByteArray, signedData: ByteArray, type: RSASignatureType): Boolean { - return when (type) { - RSASignatureType.RSASHA256, RSASignatureType.RSASHA384, RSASignatureType.RSASHA512 -> { - MainScope().promise { - crypto.subtle.verify( - publicKey.nativeType.algorithm.name, - publicKey.nativeType, - signedData.toArrayBuffer(), - data.toArrayBuffer() - ).await() - }.await() - } - RSASignatureType.RSAPSSSHA256, RSASignatureType.RSAPSSSHA384, RSASignatureType.RSAPSSSHA512 -> { - MainScope().promise { - crypto.subtle.verify( - getRsaPssParams(), - publicKey.nativeType, - signedData.toArrayBuffer(), - data.toArrayBuffer() - ).await() - }.await() - } - } - } -} diff --git a/rsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt b/rsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt deleted file mode 100644 index 95278d688..000000000 --- a/rsa/src/jsMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt +++ /dev/null @@ -1,25 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual typealias RSASignatureTypeNativeType = String - -actual final enum class RSASignatureType : NativeTypeInterface { - RSASHA256, - RSASHA384, - RSASHA512, - RSAPSSSHA256, - RSAPSSSHA384, - RSAPSSSHA512; - - override fun nativeValue(): RSASignatureTypeNativeType { - return when (this) { - RSASHA256 -> "RSA-PSS" - RSASHA384 -> "RSA-PSS" - RSASHA512 -> "RSA-PSS" - RSAPSSSHA256 -> "RSASSA-PKCS1-v1_5" - RSAPSSSHA384 -> "RSASSA-PKCS1-v1_5" - RSAPSSSHA512 -> "RSASSA-PKCS1-v1_5" - } - } -} diff --git a/rsa/src/jsTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt b/rsa/src/jsTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt deleted file mode 100644 index 736631f19..000000000 --- a/rsa/src/jsTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt +++ /dev/null @@ -1,32 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.JsHashType -import io.iohk.atala.prism.apollo.utils.KMMRSAKeyPair -import io.iohk.atala.prism.apollo.utils.RSAAsymmetricAlgorithm -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.runTest -import kotlin.test.Test -import kotlin.test.assertTrue - -@OptIn(ExperimentalCoroutinesApi::class) -actual class RSATests { - @Test - actual fun testRSA() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, JsHashType.SHA256, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256)) - } - - @Test - actual fun testRSAPSS() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, JsHashType.SHA256, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256)) - } -} diff --git a/rsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt b/rsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt deleted file mode 100644 index f17909c96..000000000 --- a/rsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSA.kt +++ /dev/null @@ -1,29 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAPrivateKey -import io.iohk.atala.prism.apollo.utils.KMMRSAPublicKey -import org.bouncycastle.jce.provider.BouncyCastleProvider -import java.security.Security -import java.security.Signature - -actual final class RSA : RSASigner, RSAVerifier { - - init { - Security.removeProvider("BC") - Security.addProvider(BouncyCastleProvider()) - } - - override suspend fun sign(privateKey: KMMRSAPrivateKey, data: ByteArray, type: RSASignatureType): ByteArray { - val signature = Signature.getInstance(type.nativeValue()) - signature.initSign(privateKey.nativeType) - signature.update(data) - return signature.sign() - } - - override suspend fun verify(publicKey: KMMRSAPublicKey, data: ByteArray, signedData: ByteArray, type: RSASignatureType): Boolean { - val signature = Signature.getInstance(type.nativeValue()) - signature.initVerify(publicKey.nativeType) - signature.update(data) - return signature.verify(signedData) - } -} diff --git a/rsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt b/rsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt deleted file mode 100644 index f0f01128c..000000000 --- a/rsa/src/jvmMain/kotlin/io/iohk/atala/prism/apollo/rsa/RSASignatureType.kt +++ /dev/null @@ -1,25 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.NativeTypeInterface - -actual typealias RSASignatureTypeNativeType = String - -actual final enum class RSASignatureType : NativeTypeInterface { - RSASHA256, - RSASHA384, - RSASHA512, - RSAPSSSHA256, - RSAPSSSHA384, - RSAPSSSHA512; - - override fun nativeValue(): String { - return when (this) { - RSASHA256 -> "SHA256withRSA" - RSASHA384 -> "SHA384withRSA" - RSASHA512 -> "SHA512withRSA" - RSAPSSSHA256 -> "SHA256withRSA/PSS" - RSAPSSSHA384 -> "SHA384withRSA/PSS" - RSAPSSSHA512 -> "SHA512withRSA/PSS" - } - } -} diff --git a/rsa/src/jvmTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt b/rsa/src/jvmTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt deleted file mode 100644 index 1c7ffa0e9..000000000 --- a/rsa/src/jvmTest/kotlin/io/iohk/atala/prism/apollo/rsa/RSATests.kt +++ /dev/null @@ -1,31 +0,0 @@ -package io.iohk.atala.prism.apollo.rsa - -import io.iohk.atala.prism.apollo.utils.KMMRSAKeyPair -import io.iohk.atala.prism.apollo.utils.RSAAsymmetricAlgorithm -import kotlinx.coroutines.ExperimentalCoroutinesApi -import kotlinx.coroutines.test.runTest -import org.junit.jupiter.api.Test -import kotlin.test.assertTrue - -@OptIn(ExperimentalCoroutinesApi::class) -actual class RSATests { - @Test - actual fun testRSA() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSA, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSASHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSASHA256)) - } - - @Test - actual fun testRSAPSS() = runTest { - val msgToSign = "Hello IOG!" - val keyPair = KMMRSAKeyPair.generateRSAKeyPair(RSAAsymmetricAlgorithm.RSAPSS, 2048) - val rsa = RSA() - val signature = rsa.sign(keyPair.privateKey, msgToSign.encodeToByteArray(), RSASignatureType.RSAPSSSHA256) - - assertTrue(rsa.verify(keyPair.publicKey, msgToSign.encodeToByteArray(), signature, RSASignatureType.RSAPSSSHA256)) - } -} diff --git a/settings.gradle.kts b/settings.gradle.kts index d33d8d0d2..7a40c78f2 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -29,10 +29,10 @@ include(":base58") include(":base64") include(":multibase") include(":utils") -include(":base-symmetric-encryption") +include(":cryptography") include(":secure-random") // include(":aes") -include(":base-asymmetric-encryption") +include(":cryptography") include(":iOSLibs") // include(":rsa") // include(":ecdsa")