diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
index d1d11f5..49e9027 100644
--- a/.gitlab-ci.yml
+++ b/.gitlab-ci.yml
@@ -54,7 +54,6 @@ macPublishToSnapshot:
script:
- ./macBuild.sh
- ./macBuildAndPublishSnapshot-bindings.sh
- - ./macBuildAndPublishSnapshot-delegated.sh
only:
- master
tags:
@@ -69,7 +68,6 @@ buildWindows:
script:
- $env:CHERE_INVOKING = 'yes'
- C:\msys64\usr\bin\bash -lc "./windowsBuild-delegated.sh"
- - C:\msys64\usr\bin\bash -lc "./windowsBuild-pure.sh"
tags:
- windowsX64
@@ -78,7 +76,6 @@ windowsPublishToSnapshot:
script:
- $env:CHERE_INVOKING = 'yes'
- C:\msys64\usr\bin\bash -lc "./windowsBuildAndPublish-delegated.sh"
- - C:\msys64\usr\bin\bash -lc "./windowsBuildAndPublish-pure.sh"
only:
- master
tags:
diff --git a/.travis.yml b/.travis.yml
deleted file mode 100644
index 278043b..0000000
--- a/.travis.yml
+++ /dev/null
@@ -1,197 +0,0 @@
-matrix:
- include:
- - os: linux
- name: linux
- language: java
- jdk: openjdk12
-
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- #skip ./gradlew assemble that is normally invoked in installation step
- install:
- - sudo apt-get update
- - sudo apt-get -y install automake
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./linuxBuild.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./linuxBuildAndPublish.sh; fi'
- # OSX macos
- - os: osx
- name: osx-mac
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-mac.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-mac.sh; fi'
- # OSX ios
- - os: osx
- name: osx-ios
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-ios.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-ios.sh; fi'
- # OSX watchos
- - os: osx
- name: osx-watchos
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-watchos.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-watchos.sh; fi'
- # OSX tvos
- - os: osx
- name: osx-tvos
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-tvos.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-tvos.sh; fi'
-
- # OSX macos PURE
- - os: osx
- name: osx-mac-pure
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-pure-mac.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-pure-mac.sh; fi'
- # OSX ios PURE
- - os: osx
- name: osx-ios-pure
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-pure-ios.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-pure-ios.sh; fi'
- # OSX watchos PURE
- - os: osx
- name: osx-watchos-pure
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-pure-watchos.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-pure-watchos.sh; fi'
- # OSX tvos PURE
- - os: osx
- name: osx-tvos-pure
- osx_image: xcode11.4
- language: java
- jdk: openjdk12
- install: true
- env:
- KBUILD=linux
- JAVA_OPTS=-Xmx2g
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then bash ./macBuild-pure-tvos.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then bash ./macBuildAndPublish-pure-tvos.sh; fi'
-
- - os: windows
- name: windows-pure
- language: shell
- jdk: openjdk12
- env:
- - GRAVIS="https://raw.githubusercontent.com/DanySK/Gravis-CI/master/"
- - JAVA_OPTS=-Xmx2g
- - JDK="adopt-openj9@1.11"
- before_install:
- - curl "${GRAVIS}.install-jdk-travis.sh" --output ~/.install-jdk-travis.sh
- - source ~/.install-jdk-travis.sh
- install: true
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then $shell ./windowsBuild-pure.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then ./windowsBuildAndPublish-pure.sh; fi'
- - os: windows
- name: windows-delegated
- language: shell
- jdk: openjdk12
- env:
- - GRAVIS="https://raw.githubusercontent.com/DanySK/Gravis-CI/master/"
- - JAVA_OPTS=-Xmx2g
- - JDK="adopt-openj9@1.11"
- before_install:
- - curl "${GRAVIS}.install-jdk-travis.sh" --output ~/.install-jdk-travis.sh
- - source ~/.install-jdk-travis.sh
- - |-
- case $TRAVIS_OS_NAME in
- windows)
- [[ ! -f C:/tools/msys64/msys2_shell.cmd ]] && rm -rf C:/tools/msys64
- choco uninstall -y mingw
- choco upgrade --no-progress -y msys2 bazel
- export msys2='cmd //C RefreshEnv.cmd '
- export msys2+='& set MSYS=winsymlinks:nativestrict '
- export msys2+='& C:\\tools\\msys64\\msys2_shell.cmd -defterm -no-start'
- export shell="$msys2 -mingw64 -full-path -here -c \$\* --"
- export msys2+=" -msys2 -c \$\* --"
- $msys2 pacman --sync --noconfirm --needed \
- autoconf \
- automake \
- mingw-w64-x86_64-libtool \
- mingw-w64-x86_64-toolchain \
- perl \
- unzip
- taskkill //IM gpg-agent.exe //F
- export CPPFLAGS=-D__USE_MINGW_ANSI_STDIO=1
- export PATH=/C/tools/msys64/mingw64/bin:$PATH
- export GNU_MAKE=mingw32-make
- export MAKE=mingw32-make
- export AR=gcc-ar
- export RANLIB=gcc-ranlib
- export COVERITY_SCAN_BRANCH_PATTERN=disable_coverity_scan
- ;;
- esac
- - export GIT=git
- - g++ --version
- - $GNU_MAKE --version
- - $GIT --version
- install: true
- before_cache:
- - $msys2 pacman --sync --clean --noconfirm
- script:
- - 'if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then $shell ./windowsBuild-delegated.sh; fi'
- - 'if [ "$TRAVIS_PULL_REQUEST" = "false" ]; then $shell ./windowsBuildAndPublish-delegated.sh; fi'
-cache:
- directories:
- - $HOME/.m2/
- - $HOME/.gradle
- - $HOME/.konan
- - $HOME/AppData/Local/Temp/chocolatey
- - /C/tools/msys64
-branches:
- only:
- - master
diff --git a/README.md b/README.md
index 5b76552..4188c2b 100644
--- a/README.md
+++ b/README.md
@@ -1,5 +1,5 @@
-[data:image/s3,"s3://crabby-images/6715a/6715a5b5351fa580193e15aaa41e240b8c3d82c9" alt="pipeline status"](https://gitlab.com/ionspin-github-ci/kotlin-multiplatform-crypto-ci/-/commits/master)
+[data:image/s3,"s3://crabby-images/d5784/d5784cc0c56e6b5d4d121a86335a76c26c74dd59" alt="pipeline status"](https://gitlab.com/ionspin-github-ci/kotlin-multiplatform-libsodium/-/commits/master)
data:image/s3,"s3://crabby-images/ee9d1/ee9d15807e6d6fe8b0a7a7da798c3d9e2a1de5ae" alt="Danger: Experimental"
@@ -108,6 +108,7 @@ And here is the usage sample
The functions are mapped from libsodium to kotiln objects, so `crypto_secretstream_xchacha20poly1305_init_push` becomes
`SecretStream.xChaCha20Poly1305InitPush`
+data:image/s3,"s3://crabby-images/8e0a5/8e0a5944aef479251912bed6c8c7e3f7bd62ef19" alt="Alt text"
At the moment you should refer to original libsodium documentation for instructions on how to use the library
@@ -139,6 +140,7 @@ Currently supported native platforms:
- Android testing
- Fix browser testing, both locally and in CI/CD
- LobsodiumUtil `unpad` and `fromBase64` native implementations use a nasty hack to support shared native sourceset. The hack either needs to be removed and replaced with another solution or additional safeguards need to be added.
+- Complete exposing libsodium constants
diff --git a/buildSrc/src/main/kotlin/Deps.kt b/buildSrc/src/main/kotlin/Deps.kt
index 395c929..edf6f4a 100644
--- a/buildSrc/src/main/kotlin/Deps.kt
+++ b/buildSrc/src/main/kotlin/Deps.kt
@@ -15,13 +15,13 @@
*/
object Versions {
- val kotlinCoroutines = "1.3.9"
- val kotlin = "1.4.10"
- val kotlinSerialization = "1.0.0"
+ val kotlinCoroutines = "1.4.1"
+ val kotlin = "1.4.20"
+ val kotlinSerialization = "1.0.1"
val kotlinSerializationPlugin = "1.4.10"
val atomicfu = "0.14.3-M2-2-SNAPSHOT" //NOTE: my linux arm32 and arm64 build
val nodePlugin = "1.3.0"
- val dokkaPlugin = "1.4.0-rc"
+ val dokkaPlugin = "1.4.0"
val taskTreePlugin = "1.5"
val kotlinBigNumVersion = "0.2.2"
val lazySodium = "4.3.1-SNAPSHOT"
diff --git a/doc/res/libsodium_api_mapping.svg b/doc/res/libsodium_api_mapping.svg
new file mode 100644
index 0000000..a4ab378
--- /dev/null
+++ b/doc/res/libsodium_api_mapping.svg
@@ -0,0 +1,91 @@
+
+
diff --git a/linuxBuild.sh b/linuxBuild.sh
index 332984c..4e520d7 100755
--- a/linuxBuild.sh
+++ b/linuxBuild.sh
@@ -15,10 +15,8 @@ fi
./makeLinuxArm64.sh
#now we can do the delegated build
cd ..
-./gradlew multiplatform-crypto-delegated:build
+
#build libsodium bindings
./gradlew multiplatform-crypto-libsodium-bindings:build
-#and finally pure build
-./gradlew multiplatform-crypto:build
set +e
diff --git a/linuxBuildAndPublish.sh b/linuxBuildAndPublish.sh
index 719e4d5..d497cdb 100755
--- a/linuxBuildAndPublish.sh
+++ b/linuxBuildAndPublish.sh
@@ -15,11 +15,9 @@ fi
./makeLinuxArm64.sh
#now we can do the delegated build
cd ..
-./gradlew multiplatform-crypto-delegated:build
#build libsodium bindings
./gradlew multiplatform-crypto-libsodium-bindings:build
-#and finally pure build
-./gradlew multiplatform-crypto:build
+
./gradlew publishJvmPublicationToSnapshotRepository publishJsPublicationToSnapshotRepository \
publishKotlinMultiplatformPublicationToSnapshotRepository publishLinuxX64PublicationToSnapshotRepository \
publishLinuxArm64PublicationToSnapshotRepository publishMetadataPublicationToSnapshotRepository
diff --git a/macBuild-ios.sh b/macBuild-ios.sh
index 2fbd792..d1143e4 100755
--- a/macBuild-ios.sh
+++ b/macBuild-ios.sh
@@ -8,10 +8,6 @@ cd sodiumWrapper
./makeIos.sh
#now we can do the delegated build of ios and macos libraries
cd ..
-./gradlew multiplatform-crypto-delegated:iosArm32MainKlibrary multiplatform-crypto-delegated:iosArm32TestKlibrary \
-multiplatform-crypto-delegated:iosArm64MainKlibrary multiplatform-crypto-delegated:iosArm64TestKlibrary \
-multiplatform-crypto-delegated:iosX64MainKlibrary multiplatform-crypto-delegated:iosX64TestKlibrary
-./gradlew multiplatform-crypto-delegated:iosX64Test
./gradlew multiplatform-crypto-libsodium-bindings:iosArm32MainKlibrary multiplatform-crypto-libsodium-bindings:iosArm32TestKlibrary \
multiplatform-crypto-libsodium-bindings:iosArm64MainKlibrary multiplatform-crypto-libsodium-bindings:iosArm64TestKlibrary \
diff --git a/macBuild-mac.sh b/macBuild-mac.sh
index bb42c97..52498e1 100755
--- a/macBuild-mac.sh
+++ b/macBuild-mac.sh
@@ -8,9 +8,6 @@ cd sodiumWrapper
./makeIos.sh
#now we can do the delegated build of ios and macos libraries
cd ..
-./gradlew multiplatform-crypto-delegated:macosX64MainKlibrary multiplatform-crypto-delegated:macosX64TestKlibrary
-./gradlew multiplatform-crypto-delegated:macosX64Test
-
./gradlew multiplatform-crypto-libsodium-bindings:macosX64MainKlibrary multiplatform-crypto-libsodium-bindings:macosX64TestKlibrary
./gradlew multiplatform-crypto-libsodium-bindings:macosX64Test
set +e
diff --git a/macBuild-pure-ios.sh b/macBuild-pure-ios.sh
deleted file mode 100755
index 85dc166..0000000
--- a/macBuild-pure-ios.sh
+++ /dev/null
@@ -1,9 +0,0 @@
-set -e
-#!/bin/sh
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:iosArm32MainKlibrary multiplatform-crypto:iosArm32TestKlibrary \
-multiplatform-crypto:iosArm64MainKlibrary multiplatform-crypto:iosArm64TestKlibrary \
-multiplatform-crypto:iosX64MainKlibrary multiplatform-crypto:iosX64TestKlibrary
-./gradlew multiplatform-crypto:iosX64Test
-
-set +e
diff --git a/macBuild-pure-mac.sh b/macBuild-pure-mac.sh
deleted file mode 100755
index 66b5ae4..0000000
--- a/macBuild-pure-mac.sh
+++ /dev/null
@@ -1,7 +0,0 @@
-set -e
-#!/bin/sh
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:macosX64MainKlibrary multiplatform-crypto:macosX64TestKlibrary
-./gradlew multiplatform-crypto:macosX64Test
-
-set +e
diff --git a/macBuild-pure-tvos.sh b/macBuild-pure-tvos.sh
deleted file mode 100755
index b9c6e22..0000000
--- a/macBuild-pure-tvos.sh
+++ /dev/null
@@ -1,7 +0,0 @@
-set -e
-#!/bin/sh
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:tvosArm64MainKlibrary multiplatform-crypto:tvosArm64TestKlibrary \
-multiplatform-crypto:tvosX64MainKlibrary multiplatform-crypto:tvosX64TestKlibrary
-./gradlew multiplatform-crypto:tvosX64Test
-set +e
diff --git a/macBuild-pure-watchos.sh b/macBuild-pure-watchos.sh
deleted file mode 100755
index 75dd98b..0000000
--- a/macBuild-pure-watchos.sh
+++ /dev/null
@@ -1,8 +0,0 @@
-set -e
-#!/bin/sh
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:watchosArm32MainKlibrary multiplatform-crypto:watchosArm32TestKlibrary \
-multiplatform-crypto:watchosArm64MainKlibrary multiplatform-crypto:watchosArm64TestKlibrary \
-multiplatform-crypto:watchosX86MainKlibrary multiplatform-crypto:watchosX86TestKlibrary
-./gradlew multiplatform-crypto:watchosX86Test
-set +e
diff --git a/macBuild-tvos.sh b/macBuild-tvos.sh
index 0fbc520..154841d 100755
--- a/macBuild-tvos.sh
+++ b/macBuild-tvos.sh
@@ -7,9 +7,6 @@ cd sodiumWrapper
./makeTvos.sh
#now we can do the delegated build of ios and macos libraries
cd ..
-./gradlew multiplatform-crypto-delegated:tvosArm64MainKlibrary multiplatform-crypto-delegated:tvosArm64TestKlibrary \
-multiplatform-crypto-delegated:tvosX64MainKlibrary multiplatform-crypto-delegated:tvosX64TestKlibrary
-./gradlew multiplatform-crypto-delegated:tvosX64Test
./gradlew multiplatform-crypto-libsodium-bindings:tvosArm64MainKlibrary multiplatform-crypto-libsodium-bindings:tvosArm64TestKlibrary \
multiplatform-crypto-libsodium-bindings:tvosX64MainKlibrary multiplatform-crypto-libsodium-bindings:tvosX64TestKlibrary
diff --git a/macBuild-watchos.sh b/macBuild-watchos.sh
index 6935420..6311ae4 100755
--- a/macBuild-watchos.sh
+++ b/macBuild-watchos.sh
@@ -7,10 +7,6 @@ cd sodiumWrapper
./makeWatchos.sh
#now we can do the delegated build of ios and macos libraries
cd ..
-./gradlew multiplatform-crypto-delegated:watchosArm32MainKlibrary multiplatform-crypto-delegated:watchosArm32TestKlibrary \
-multiplatform-crypto-delegated:watchosArm64MainKlibrary multiplatform-crypto-delegated:watchosArm64TestKlibrary \
-multiplatform-crypto-delegated:watchosX86MainKlibrary multiplatform-crypto-delegated:watchosX86TestKlibrary
-./gradlew multiplatform-crypto-delegated:watchosX86Test
./gradlew multiplatform-crypto-libsodium-bindings:watchosArm32MainKlibrary multiplatform-crypto-libsodium-bindings:watchosArm32TestKlibrary \
multiplatform-crypto-libsodium-bindings:watchosArm64MainKlibrary multiplatform-crypto-libsodium-bindings:watchosArm64TestKlibrary \
diff --git a/macBuild.sh b/macBuild.sh
index 23d0c7c..b12ed96 100755
--- a/macBuild.sh
+++ b/macBuild.sh
@@ -8,9 +8,6 @@ cd sodiumWrapper
./makeIosWatchosTvos.sh
#now we can do the delegated build
cd ..
-./gradlew multiplatform-crypto-delegated:build
-#pure build
-./gradlew multiplatform-crypto:build
#libsodium bindings
./gradlew multiplatform-crypto-libsodium-bindings:build
set +e
diff --git a/macBuildAndPublish-ios.sh b/macBuildAndPublish-ios.sh
index d506639..ac8dbb1 100755
--- a/macBuildAndPublish-ios.sh
+++ b/macBuildAndPublish-ios.sh
@@ -8,9 +8,6 @@ cd sodiumWrapper
./makeIos.sh
#now we can do the delegated build of ios and macos libraries
cd ..
-./gradlew multiplatform-crypto-delegated:publishIosArm32PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishIosArm64PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishIosX64PublicationToSnapshotRepository
./gradlew multiplatform-crypto-libsodium-bindings:publishIosArm32PublicationToSnapshotRepository \
multiplatform-crypto-libsodium-bindings:publishIosArm64PublicationToSnapshotRepository \
diff --git a/macBuildAndPublish-mac.sh b/macBuildAndPublish-mac.sh
index c92cf58..df18499 100755
--- a/macBuildAndPublish-mac.sh
+++ b/macBuildAndPublish-mac.sh
@@ -7,7 +7,6 @@ cd sodiumWrapper
./makeMacosX86-64.sh
#now we can do the delegated build of ios and macos libraries
cd ..
-./gradlew multiplatform-crypto-delegated:publishMacosX64PublicationToSnapshotRepository
./gradlew multiplatform-crypto-libsodium-bindings:publishMacosX64PublicationToSnapshotRepository
set +e
diff --git a/macBuildAndPublish-pure-ios.sh b/macBuildAndPublish-pure-ios.sh
deleted file mode 100755
index 6095c54..0000000
--- a/macBuildAndPublish-pure-ios.sh
+++ /dev/null
@@ -1,8 +0,0 @@
-set -e
-#!/bin/sh
-#this will hopefully download all konan dependancies that we use in the build scripts
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:publishIosArm32PublicationToSnapshotRepository \
-multiplatform-crypto:publishIosArm64PublicationToSnapshotRepository \
-multiplatform-crypto:publishIosX64PublicationToSnapshotRepository
-set +e
diff --git a/macBuildAndPublish-pure-mac.sh b/macBuildAndPublish-pure-mac.sh
deleted file mode 100755
index 6dc40b5..0000000
--- a/macBuildAndPublish-pure-mac.sh
+++ /dev/null
@@ -1,6 +0,0 @@
-set -e
-#!/bin/sh
-#this will hopefully download all konan dependancies that we use in the build scripts
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:publishMacosX64PublicationToSnapshotRepository
-set +e
diff --git a/macBuildAndPublish-pure-tvos.sh b/macBuildAndPublish-pure-tvos.sh
deleted file mode 100755
index 1533e8d..0000000
--- a/macBuildAndPublish-pure-tvos.sh
+++ /dev/null
@@ -1,8 +0,0 @@
-set -e
-#!/bin/sh
-#this will hopefully download all konan dependancies that we use in the build scripts
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:publishTvosArm64PublicationToSnapshotRepository \
-multiplatform-crypto:publishTvosX64PublicationToSnapshotRepository
-
-set +e
diff --git a/macBuildAndPublish-pure-watchos.sh b/macBuildAndPublish-pure-watchos.sh
deleted file mode 100755
index 30724cd..0000000
--- a/macBuildAndPublish-pure-watchos.sh
+++ /dev/null
@@ -1,8 +0,0 @@
-set -e
-#!/bin/sh
-#this will hopefully download all konan dependancies that we use in the build scripts
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:publishWatchosArm32PublicationToSnapshotRepository \
-multiplatform-crypto:publishWatchosArm64PublicationToSnapshotRepository \
-multiplatform-crypto:publishWatchosX86PublicationToSnapshotRepository
-set +e
diff --git a/macBuildAndPublish-tvos.sh b/macBuildAndPublish-tvos.sh
deleted file mode 100755
index 1533e8d..0000000
--- a/macBuildAndPublish-tvos.sh
+++ /dev/null
@@ -1,8 +0,0 @@
-set -e
-#!/bin/sh
-#this will hopefully download all konan dependancies that we use in the build scripts
-./gradlew multiplatform-crypto-api:build
-./gradlew multiplatform-crypto:publishTvosArm64PublicationToSnapshotRepository \
-multiplatform-crypto:publishTvosX64PublicationToSnapshotRepository
-
-set +e
diff --git a/macBuildAndPublish-watchos.sh b/macBuildAndPublish-watchos.sh
index 3125ec4..ee42802 100755
--- a/macBuildAndPublish-watchos.sh
+++ b/macBuildAndPublish-watchos.sh
@@ -7,9 +7,6 @@ cd sodiumWrapper
./makeWatchos.sh
#now we can do the delegated build of ios and macos libraries
cd ..
-./gradlew multiplatform-crypto-delegated:publishWatchosArm32PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishWatchosArm64PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishWatchosX86PublicationToSnapshotRepository
./gradlew multiplatform-crypto-libsodium-bindings:publishWatchosArm32PublicationToSnapshotRepository \
multiplatform-crypto-libsodium-bindings:publishWatchosArm64PublicationToSnapshotRepository \
diff --git a/macBuildAndPublishSnapshot-delegated.sh b/macBuildAndPublishSnapshot-delegated.sh
deleted file mode 100755
index 8fb7d2d..0000000
--- a/macBuildAndPublishSnapshot-delegated.sh
+++ /dev/null
@@ -1,15 +0,0 @@
-set -e
-#!/bin/sh
-./gradlew multiplatform-crypto-delegated:publishMacosX64PublicationToSnapshotRepository
-
-./gradlew multiplatform-crypto-delegated:publishIosArm32PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishIosArm64PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishIosX64PublicationToSnapshotRepository
-
-./gradlew multiplatform-crypto-delegated:publishWatchosArm32PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishWatchosArm64PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishWatchosX86PublicationToSnapshotRepository
-
-./gradlew multiplatform-crypto-delegated:publishTvosArm64PublicationToSnapshotRepository \
-multiplatform-crypto-delegated:publishTvosX64PublicationToSnapshotRepository
-set +e
diff --git a/multiplatform-crypto-api/build.gradle.kts b/multiplatform-crypto-api/build.gradle.kts
index 7cb696a..4c655f0 100644
--- a/multiplatform-crypto-api/build.gradle.kts
+++ b/multiplatform-crypto-api/build.gradle.kts
@@ -19,6 +19,7 @@
import org.jetbrains.kotlin.gradle.targets.js.testing.KotlinJsTest
import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest
+import org.jetbrains.dokka.Platform
plugins {
kotlin(PluginsDeps.multiplatform)
@@ -275,9 +276,9 @@ tasks {
dokkaJavadoc {
println("Dokka !")
dokkaSourceSets {
- create("commonMain") {
- displayName = "common"
- platform = "common"
+ named("commonMain") {
+ displayName.set("common")
+ platform.set(Platform.common)
}
}
diff --git a/multiplatform-crypto-delegated/build.gradle.kts b/multiplatform-crypto-delegated/build.gradle.kts
deleted file mode 100644
index 77b5912..0000000
--- a/multiplatform-crypto-delegated/build.gradle.kts
+++ /dev/null
@@ -1,697 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *
- */
-
-@file:Suppress("UnstableApiUsage")
-
-import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget
-import org.jetbrains.kotlin.gradle.targets.js.testing.KotlinJsTest
-import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest
-
-plugins {
- kotlin(PluginsDeps.multiplatform)
- id(PluginsDeps.mavenPublish)
- id(PluginsDeps.signing)
- id(PluginsDeps.node) version Versions.nodePlugin
- id(PluginsDeps.dokka)
- id(PluginsDeps.taskTree) version Versions.taskTreePlugin
-}
-
-val sonatypeStaging = "https://oss.sonatype.org/service/local/staging/deploy/maven2/"
-val sonatypeSnapshots = "https://oss.sonatype.org/content/repositories/snapshots/"
-
-val sonatypePassword: String? by project
-
-val sonatypeUsername: String? by project
-
-val sonatypePasswordEnv: String? = System.getenv()["SONATYPE_PASSWORD"]
-val sonatypeUsernameEnv: String? = System.getenv()["SONATYPE_USERNAME"]
-
-repositories {
- mavenCentral()
- jcenter()
-
-}
-group = ReleaseInfo.group
-version = ReleaseInfo.version
-
-val ideaActive = isInIdea()
-println("Idea active: $ideaActive")
-
-
-
-kotlin {
- val hostOsName = getHostOsName()
- runningOnLinuxx86_64 {
- println("Configuring Linux X86-64 targets")
- jvm()
- js {
- browser {
- testTask {
- isRunningInGitlabCi {
- enabled = false //Until I sort out testing on travis
- }
- useKarma {
- useChrome()
- }
- }
- }
- nodejs {
- testTask {
- useMocha() {
- timeout = "10s"
- }
- }
- }
-
- }
- linuxX64() {
- compilations.getByName("main") {
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-linux-x86-64/include/")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-linux-x86-64/lib/libsodium.a"
- )
- }
- binaries {
- staticLib {
- }
- }
- }
-
-
- linuxArm64() {
- binaries {
- staticLib {
- }
- }
- }
- // Linux 32 is using target-sysroot-2-raspberrypi which is missing getrandom and explicit_bzero in stdlib
- // so konanc can't build klib because getrandom missing will cause sodium_misuse()
- // ld.lld: error: undefined symbol: explicit_bzero
- // >>> referenced by utils.c
- // >>> libsodium_la-utils.o:(sodium_memzero) in archive /tmp/included11051337748775083797/libsodium.a
- //
- // ld.lld: error: undefined symbol: getrandom
- // >>> referenced by randombytes_sysrandom.c
- // >>> libsodium_la-randombytes_sysrandom.o:(_randombytes_linux_getrandom) in archive /tmp/included11051337748775083797/libsodium.a
-
-// linuxArm32Hfp() {
-// binaries {
-// staticLib {
-// }
-// }
-// compilations.getByName("main") {
-// val libsodiumCinterop by cinterops.creating {
-// defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
-// compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-arm32/include/")
-// }
-// kotlinOptions.freeCompilerArgs = listOf(
-// "-include-binary", "${project.rootDir}/sodiumWrapper/static-arm32/lib/libsodium.a"
-// )
-// }
-// }
-
-
- }
-
-
- runningOnLinuxArm64 {
- println("Configuring Linux Arm 64 targets")
-
- }
-
- runningOnLinuxArm32 {
- println("Configuring Linux Arm 32 targets")
-
- }
-
- runningOnMacos {
- println("Configuring macos targets")
- iosX64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
- iosArm64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- iosArm32() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
- macosX64() {
- binaries {
- framework {
- optimized = true
- }
- }
- compilations.getByName("main") {
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-macos-x86-64/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-macos-x86-64/lib/libsodium.a"
- )
- }
- }
- tvosX64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- tvosArm64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- watchosArm64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- watchosArm32() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- watchosX86() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
- }
- runningOnWindows {
- println("Configuring Mingw targets")
- mingwX64() {
- binaries {
- staticLib {
- optimized = true
- }
- }
- compilations.getByName("main") {
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-mingw-x86-64/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-mingw-x86-64/lib/libsodium.a"
- )
- }
- }
- }
-
- println(targets.names)
-
- sourceSets {
- val commonMain by getting {
- dependencies {
- implementation(kotlin(Deps.Common.stdLib))
- implementation(kotlin(Deps.Common.test))
- implementation(Deps.Common.kotlinBigNum)
- api(project(Deps.Common.apiProject))
- }
- }
- val commonTest by getting {
- dependencies {
- implementation(kotlin(Deps.Common.test))
- implementation(kotlin(Deps.Common.testAnnotation))
- }
- }
-
- val nativeDependencies = independentDependencyBlock {
- }
-
- val nativeMain by creating {
- dependsOn(commonMain)
- isRunningInIdea {
- kotlin.setSrcDirs(emptySet())
- }
- dependencies {
- nativeDependencies(this)
- }
- }
-
- val nativeTest by creating {
- dependsOn(commonTest)
- isRunningInIdea {
- kotlin.setSrcDirs(emptySet())
- }
- dependencies {
- }
- }
-
- //Set up shared source sets
- //linux, linuxArm32Hfp, linuxArm64
- val linux64Bit = setOf(
- "linuxX64"
- )
- val linuxArm64Bit = setOf(
- "linuxArm64"
- )
- val linux32Bit = setOf(
- "" // "linuxArm32Hfp"
- )
-
- //iosArm32, iosArm64, iosX64, macosX64, metadata, tvosArm64, tvosX64, watchosArm32, watchosArm64, watchosX86
- val macos64Bit = setOf(
- "macosX64"
- )
- val iosArm = setOf(
- "iosArm64", "iosArm32"
- )
- val iosSimulator = setOf(
- "iosX64"
- )
- val mingw64Bit = setOf(
- "mingwX64"
- )
-
- val tvosArm = setOf(
- "tvosArm64"
- )
- val tvosSimulator = setOf(
- "tvosX64"
- )
-
- val watchosArm = setOf(
- "watchosArm32", "watchosArm64"
- )
- val watchosSimulator = setOf(
- "watchosX86"
- )
-
- targets.withType {
- println("Target $name")
-
- compilations.getByName("main") {
- if (linux64Bit.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(nativeMain)
- }
- if (linuxArm64Bit.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(
- createWorkaroundNativeMainSourceSet(
- this@withType.name,
- nativeDependencies
- )
- )
-
- compilations.getByName("main") {
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-arm64/include/")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-arm64/lib/libsodium.a"
- )
- }
- }
- if (linux32Bit.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- }
- if (macos64Bit.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- }
- //All ioses share the same static library
- if (iosArm.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- println("Setting ios cinterop for $this")
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-ios/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-ios/lib/libsodium.a"
- )
- }
-
- if (iosSimulator.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- println("Setting ios cinterop for $this")
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-ios-simulators/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-ios-simulators/lib/libsodium.a"
- )
- }
-
- if (tvosArm.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- println("Setting ios cinterop for $this")
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-tvos/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-tvos/lib/libsodium.a"
- )
- }
-
- if (tvosSimulator.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- println("Setting ios cinterop for $this")
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-tvos-simulators/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-tvos-simulators/lib/libsodium.a"
- )
- }
-
- if (watchosArm.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- println("Setting ios cinterop for $this")
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-watchos/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-watchos/lib/libsodium.a"
- )
- }
-
- if (watchosSimulator.contains(this@withType.name)) {
- defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
- println("Setting ios cinterop for $this")
- val libsodiumCinterop by cinterops.creating {
- defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
- compilerOpts.add("-I${project.rootDir}/sodiumWrapper/static-watchos-simulators/include")
- }
- kotlinOptions.freeCompilerArgs = listOf(
- "-include-binary", "${project.rootDir}/sodiumWrapper/static-watchos-simulators/lib/libsodium.a"
- )
- }
-
-
-
- }
- compilations.getByName("test") {
- println("Setting native test dep for $this@withType.name")
- defaultSourceSet.dependsOn(nativeTest)
-
-
- }
- }
-
-
-
-
- runningOnLinuxx86_64 {
- println("Configuring Linux 64 Bit source sets")
- val jvmMain by getting {
- dependencies {
- implementation(kotlin(Deps.Jvm.stdLib))
- implementation(kotlin(Deps.Jvm.test))
- implementation(kotlin(Deps.Jvm.testJUnit))
-
- //lazysodium
- implementation(Deps.Jvm.Delegated.lazysodium)
- implementation(Deps.Jvm.Delegated.jna)
- }
- }
- val jvmTest by getting {
- dependencies {
- implementation(kotlin(Deps.Jvm.test))
- implementation(kotlin(Deps.Jvm.testJUnit))
- implementation(kotlin(Deps.Jvm.reflection))
- }
- }
- val jsMain by getting {
- dependencies {
- implementation(kotlin(Deps.Js.stdLib))
- implementation(npm(Deps.Js.Npm.libsodiumWrappers.first, Deps.Js.Npm.libsodiumWrappers.second))
- }
- }
- val jsTest by getting {
- dependencies {
- implementation(kotlin(Deps.Js.test))
- implementation(npm(Deps.Js.Npm.libsodiumWrappers.first, Deps.Js.Npm.libsodiumWrappers.second))
- }
- }
- val linuxX64Main by getting {
- isRunningInIdea {
- kotlin.srcDir("src/nativeMain/kotlin")
- }
- }
- val linuxX64Test by getting {
- dependsOn(nativeTest)
- isRunningInIdea {
- kotlin.srcDir("src/nativeTest/kotlin")
- }
- }
-
- }
-
- runningOnMacos {
- println("Configuring Macos source sets")
- val macosX64Main by getting {
- dependsOn(nativeMain)
- if (ideaActive) {
- kotlin.srcDir("src/nativeMain/kotlin")
- }
-
- }
- val macosX64Test by getting {
- dependsOn(nativeTest)
- if (ideaActive) {
- kotlin.srcDir("src/nativeTest/kotlin")
- }
-
- }
-
- val tvosX64Main by getting {
- dependsOn(commonMain)
- }
-
- val tvosArm64Main by getting {
- dependsOn(commonMain)
- }
-
- val watchosX86Main by getting {
- dependsOn(commonMain)
- }
-
- val watchosArm64Main by getting {
- dependsOn(commonMain)
- }
-
- val watchosArm32Main by getting {
- dependsOn(commonMain)
- }
-
- }
-
-
- if (hostOsName == "windows") {
- val mingwX64Main by getting {
- dependsOn(nativeMain)
- if (ideaActive) {
- kotlin.srcDir("src/nativeMain/kotlin")
- }
- }
-
- val mingwX64Test by getting {
- dependsOn(nativeTest)
- if (ideaActive) {
- kotlin.srcDir("src/nativeTest/kotlin")
- }
- }
- }
-
-
- all {
- languageSettings.enableLanguageFeature("InlineClasses")
- languageSettings.useExperimentalAnnotation("kotlin.ExperimentalUnsignedTypes")
- languageSettings.useExperimentalAnnotation("kotlin.ExperimentalStdlibApi")
- }
- }
-
-
-}
-
-
-
-tasks {
-
-
- create("javadocJar") {
- dependsOn(dokkaJavadoc)
- archiveClassifier.set("javadoc")
- from(dokkaJavadoc.get().outputDirectory)
- }
-
- dokkaJavadoc {
- println("Dokka !")
- dokkaSourceSets {
- create("commonMain") {
- displayName = "common"
- platform = "common"
- }
- }
-
- }
- if (getHostOsName() == "linux" && getHostArchitecture() == "x86-64") {
- val jvmTest by getting(Test::class) {
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
- }
- }
-
- val linuxX64Test by getting(KotlinNativeTest::class) {
-
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
- showStandardStreams = true
- }
- }
-
- val jsNodeTest by getting(KotlinJsTest::class) {
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
-// showStandardStreams = true
- }
- }
-
-// val legacyjsNodeTest by getting(KotlinJsTest::class) {
-//
-// testLogging {
-// events("PASSED", "FAILED", "SKIPPED")
-// showStandardStreams = true
-// }
-// }
-
-// val jsIrBrowserTest by getting(KotlinJsTest::class) {
-// testLogging {
-// events("PASSED", "FAILED", "SKIPPED")
-// showStandardStreams = true
-// }
-// }
- }
-
- if (getHostOsName() == "windows") {
- val mingwX64Test by getting(KotlinNativeTest::class) {
-
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
- showStandardStreams = true
- }
- }
- }
-
-}
-
-
-
-signing {
- isRequired = false
- sign(publishing.publications)
-}
-
-publishing {
- publications.withType(MavenPublication::class) {
- artifact(tasks["javadocJar"])
- pom {
- name.set("Kotlin Multiplatform Crypto")
- description.set("Kotlin Multiplatform Crypto library")
- url.set("https://github.com/ionspin/kotlin-multiplatform-crypto")
- licenses {
- license {
- name.set("The Apache License, Version 2.0")
- url.set("http://www.apache.org/licenses/LICENSE-2.0.txt")
- }
- }
- developers {
- developer {
- id.set("ionspin")
- name.set("Ugljesa Jovanovic")
- email.set("opensource@ionspin.com")
- }
- }
- scm {
- url.set("https://github.com/ionspin/kotlin-multiplatform-crypto")
- connection.set("scm:git:git://git@github.com:ionspin/kotlin-multiplatform-crypto.git")
- developerConnection.set("scm:git:ssh://git@github.com:ionspin/kotlin-multiplatform-crypto.git")
-
- }
-
- }
- }
- repositories {
- maven {
-
- url = uri(sonatypeStaging)
- credentials {
- username = sonatypeUsername ?: sonatypeUsernameEnv ?: ""
- password = sonatypePassword ?: sonatypePasswordEnv ?: ""
- }
- }
-
- maven {
- name = "snapshot"
- url = uri(sonatypeSnapshots)
- credentials {
- username = sonatypeUsername ?: sonatypeUsernameEnv ?: ""
- password = sonatypePassword ?: sonatypePasswordEnv ?: ""
- }
- }
- }
-}
-
-//configurations.forEach {
-//
-// if (it.name == "linuxCompileKlibraries") {
-// println("Configuration name: ${it.name}")
-// it.attributes {
-// this.keySet().forEach { key ->
-// val attribute = getAttribute(key)
-// println(" |-- Attribute $key ${attribute}")
-// attribute(org.jetbrains.kotlin.gradle.plugin.ProjectLocalConfigurations.ATTRIBUTE, "publicZ")
-// }
-// }
-// }
-//}
-
-
diff --git a/multiplatform-crypto-delegated/libsodium-wrappers-sumo-0.7.6.tgz b/multiplatform-crypto-delegated/libsodium-wrappers-sumo-0.7.6.tgz
deleted file mode 100644
index 97837ca..0000000
Binary files a/multiplatform-crypto-delegated/libsodium-wrappers-sumo-0.7.6.tgz and /dev/null differ
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Config.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Config.kt
deleted file mode 100644
index eb058b8..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Config.kt
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 20-Jul-2019
- */
-object Config {
- const val DEBUG = false
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Crypto.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Crypto.kt
deleted file mode 100644
index 4507c00..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Crypto.kt
+++ /dev/null
@@ -1,216 +0,0 @@
-package com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.authenticated.XChaCha20Poly1305Delegated
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bProperties
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bDelegated
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bDelegatedStateless
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bMultipart
-import com.ionspin.kotlin.crypto.hash.sha.*
-import com.ionspin.kotlin.crypto.keyderivation.ArgonResult
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 24-May-2020
- */
-
-object CryptoInitializerDelegated : CryptoInitializer {
- override suspend fun initialize() {
- Initializer.initialize()
- }
-
- fun initializeWithCallback(done: () -> Unit) {
- Initializer.initializeWithCallback(done)
- }
-
- override fun isInitialized(): Boolean {
- return Initializer.isInitialized()
- }
-}
-
-object CryptoPrimitives : PrimitivesApi {
-
- object Blake2b {
- fun updateable(key: UByteArray? = null, hashLength: Int = Blake2bProperties.MAX_HASH_BYTES): com.ionspin.kotlin.crypto.hash.blake2b.Blake2bMultipart {
- checkInitialization()
- return Blake2bDelegated(key, hashLength)
- }
-
- fun stateless(message: UByteArray, key: UByteArray = ubyteArrayOf(), hashLength: Int = Blake2bProperties.MAX_HASH_BYTES): UByteArray {
- checkInitialization()
- return Blake2bDelegatedStateless.digest(message, key, hashLength)
- }
- }
-
- object Sha256 {
- fun updateable(): com.ionspin.kotlin.crypto.hash.sha.Sha256 {
- checkInitialization()
- return Sha256Delegated()
- }
-
- fun stateless(message: UByteArray) : UByteArray{
- checkInitialization()
- return Sha256StatelessDelegated.digest(inputMessage = message)
- }
- }
-
- object Sha512 {
- fun updateable(): Sha512Multipart {
- checkInitialization()
- return Sha512Delegated()
- }
-
- fun stateless(message: UByteArray) : UByteArray {
- checkInitialization()
- return Sha512StatelessDelegated.digest(inputMessage = message)
- }
- }
-
- private fun checkInitialization() {
- if (!Initializer.isInitialized()) {
- throw RuntimeException("Platform library not initialized, check if you called Initializer.initialize()")
- }
- }
-
- override fun hashBlake2bMultipart(key: UByteArray?, hashLength: Int): Blake2bMultipart {
- checkInitialization()
- return Blake2bDelegated(key, hashLength)
- }
-
- override fun hashBlake2b(message: UByteArray, key: UByteArray, hashLength: Int): UByteArray {
- checkInitialization()
- return Blake2bDelegatedStateless.digest(message, key, hashLength)
- }
-
- override fun hashSha256Multipart(): com.ionspin.kotlin.crypto.hash.sha.Sha256 {
- checkInitialization()
- return Sha256Delegated()
- }
-
- override fun hashSha256(message: UByteArray): UByteArray {
- checkInitialization()
- return Sha256StatelessDelegated.digest(inputMessage = message)
- }
-
- override fun hashSha512Multipart(): com.ionspin.kotlin.crypto.hash.sha.Sha512Multipart {
- checkInitialization()
- return Sha512Delegated()
- }
-
- override fun hashSha512(message: UByteArray): UByteArray {
- checkInitialization()
- return Sha512StatelessDelegated.digest(inputMessage = message)
- }
-
- override fun deriveKey(
- password: String,
- salt: String?,
- key: String,
- associatedData: String,
- parallelism: Int,
- tagLength: Int,
- memory: Int,
- numberOfIterations: Int
- ): ArgonResult {
-// return Argon2Delegated.derive(
-// password,
-// salt,
-// key,
-// associatedData,
-// parallelism
-// tagLength,
-// memory,
-// numberOfIterations
-// )
- TODO()
- }
-
-}
-
-
-fun SymmetricKey.Companion.randomKey() : SymmetricKey {
- return SymmetricKey(SRNG.getRandomBytes(32))
-}
-
-object Crypto {
-
- object Hash : HashApi {
- override fun hash(data: UByteArray, key : UByteArray) : HashedData {
- return HashedData(Blake2bDelegatedStateless.digest(data, key))
- }
-
- override fun multipartHash(key: UByteArray?) : com.ionspin.kotlin.crypto.hash.MultipartHash {
- return Blake2bDelegated(key)
- }
- }
-
- object Encryption : EncryptionApi {
- override fun encrypt(key: SymmetricKey, data : Encryptable<*>, associatedData : UByteArray) : EncryptedData {
- if (key.value.size != 32) {
- throw RuntimeException("Invalid key size! Required 32, supplied ${key.value.size}")
- }
- val nonce = SRNG.getRandomBytes(24)
- return EncryptedData(XChaCha20Poly1305Delegated.encrypt(key.value, nonce, data.toEncryptableForm(), associatedData), nonce)
-
- }
-
- override fun > decrypt(key: SymmetricKey, encryptedData : EncryptedData, associatedData: UByteArray, byteArrayDeserializer : (UByteArray) -> T) : T {
- return byteArrayDeserializer(XChaCha20Poly1305Delegated.decrypt(key.value, encryptedData.nonce, encryptedData.ciphertext, associatedData))
-
- }
-
- override fun createMultipartEncryptor(key: SymmetricKey): MultipartAuthenticatedEncryption {
- return MultipartAuthenticatedEncryptor(key)
- }
-
- override fun createMultipartDecryptor(key: SymmetricKey, header: MultipartEncryptionHeader) : MultipartAuthenticatedDecryption {
- val decryptor = XChaCha20Poly1305Delegated()
- decryptor.initializeForDecryption(key.value, header.nonce)
- return MultipartAuthenticatedDecryptor(decryptor)
- }
-
-
- }
-}
-
-class MultipartAuthenticatedEncryptor internal constructor(val key : SymmetricKey) : MultipartAuthenticatedEncryption {
-
- val header : MultipartEncryptionHeader
- val primitive = XChaCha20Poly1305Delegated()
- init {
- header = MultipartEncryptionHeader(primitive.initializeForEncryption(key.value))
- }
-
- override fun startEncryption(): MultipartEncryptionHeader {
- return header
- }
-
- override fun encryptPartialData(data: UByteArray, associatedData: UByteArray): EncryptedDataPart {
- return EncryptedDataPart(primitive.encrypt(data, associatedData))
- }
-
- override fun cleanup() {
- primitive.cleanup()
- }
-}
-
-
-class MultipartAuthenticatedDecryptor internal constructor(val decryptor: XChaCha20Poly1305Delegated) : MultipartAuthenticatedDecryption {
- override fun decryptPartialData(data: EncryptedDataPart, associatedData: UByteArray): DecryptedDataPart {
- return DecryptedDataPart(decryptor.decrypt(data.data, associatedData))
- }
-
- override fun cleanup() {
- decryptor.cleanup()
- }
-
-}
-
-expect object Initializer {
- fun isInitialized() : Boolean
-
- suspend fun initialize()
-
- fun initializeWithCallback(done: () -> (Unit))
-}
-
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/NativeInlineClassEmitter.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/NativeInlineClassEmitter.kt
deleted file mode 100644
index deda2be..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/NativeInlineClassEmitter.kt
+++ /dev/null
@@ -1,12 +0,0 @@
-package _multiplatform_crypto_delegated
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 24-May-2020
- */
-//Workaround for https://youtrack.jetbrains.com/issue/KT-36878
-val byteArray = byteArrayOf(0)
-val byte = 0.toByte()
-val longArray = longArrayOf(0)
-val long = 0L
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index 80e6f05..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-expect object SRNG {
- fun getRandomBytes(amount : Int) : UByteArray
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/DelegatedXChaCha20Poly1305.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/DelegatedXChaCha20Poly1305.kt
deleted file mode 100644
index 5f92fc8..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/DelegatedXChaCha20Poly1305.kt
+++ /dev/null
@@ -1,24 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jun-2020
- */
-expect class XChaCha20Poly1305Delegated internal constructor() {
- internal constructor(key: UByteArray, testState : UByteArray, testHeader: UByteArray, isDecryptor: Boolean)
- companion object {
- fun encrypt(key: UByteArray, nonce: UByteArray, message: UByteArray, associatedData: UByteArray) : UByteArray
- fun decrypt(key: UByteArray, nonce: UByteArray, ciphertext: UByteArray, associatedData: UByteArray) : UByteArray
- }
- fun initializeForEncryption(key: UByteArray) : UByteArray
- fun initializeForDecryption(key: UByteArray, header: UByteArray)
- fun encrypt(data: UByteArray, associatedData: UByteArray = ubyteArrayOf()) : UByteArray
- fun decrypt(data: UByteArray, associatedData: UByteArray = ubyteArrayOf()) : UByteArray
- fun cleanup()
-
-
-}
-
-
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
deleted file mode 100644
index 4887631..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jul-2019
- */
-
-
-expect class Blake2bDelegated(key: UByteArray? = null, hashLength: Int = Blake2bProperties.MAX_HASH_BYTES) : Blake2bMultipart
-
-
-expect object Blake2bDelegatedStateless : Blake2b
-
-
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
deleted file mode 100644
index b53b3df..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-expect class Sha256Delegated() : Sha256
-
-expect object Sha256StatelessDelegated : StatelessSha256
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
deleted file mode 100644
index 8d5b857..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-expect class Sha512Delegated() : Sha512Multipart
-
-expect object Sha512StatelessDelegated : Sha512
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2.kt
deleted file mode 100644
index 707a664..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2.kt
+++ /dev/null
@@ -1,10 +0,0 @@
-package com.ionspin.kotlin.crypto.keyderivation.argon2
-
-import com.ionspin.kotlin.crypto.keyderivation.KeyDerivationFunction
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 24-May-2020
- */
-interface Argon2 : KeyDerivationFunction
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/parallelization/Coroutines14.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/parallelization/Coroutines14.kt
deleted file mode 100644
index 6a05cbb..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/parallelization/Coroutines14.kt
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.parallelization
-
-import kotlin.time.ExperimentalTime
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-May-2020
- */
-@ExperimentalTime
-object Coroutines14 {
- fun argonParallel() : Array {
-// val argon = Argon2()
-// argon
- println("Placeholder")
- return emptyArray()
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/util/Util.kt b/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/util/Util.kt
deleted file mode 100644
index b24e406..0000000
--- a/multiplatform-crypto-delegated/src/commonMain/kotlin/com/ionspin/kotlin/crypto/util/Util.kt
+++ /dev/null
@@ -1,216 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_API_USAGE")
-
-package com.ionspin.kotlin.crypto.util
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 15-Jul-2019
- */
-
-
-inline fun Array.chunked(sliceSize: Int): Array> {
- val last = this.size % sliceSize
- val hasLast = last != 0
- val numberOfSlices = this.size / sliceSize
-
-
- val result : MutableList> = MutableList>(0) { emptyList() }
-
- for (i in 0 until numberOfSlices) {
- result.add(this.slice(i * sliceSize until (i + 1) * sliceSize))
- }
- if (hasLast) {
- result.add(this.slice(numberOfSlices * sliceSize until this.size))
- }
-
- return result.map { it.toTypedArray() }.toTypedArray()
-
-}
-
-
-infix fun UInt.rotateRight(places: Int): UInt {
- return (this shr places) xor (this shl (32 - places))
-}
-
-
-infix fun ULong.rotateRight(places: Int): ULong {
- return (this shr places) xor (this shl (64 - places))
-}
-
-
-infix fun Array.xor(other : Array) : Array {
- if (this.size != other.size) {
- throw RuntimeException("Operands of different sizes are not supported yet")
- }
- return Array(this.size) { this[it] xor other[it] }
-}
-
-
-infix fun UByteArray.xor(other : UByteArray) : UByteArray {
- if (this.size != other.size) {
- throw RuntimeException("Operands of different sizes are not supported yet")
- }
- return UByteArray(this.size) { this[it] xor other[it] }
-}
-
-
-
-
-
-// UInt / Array utils
-
-fun UInt.toBigEndianUByteArray() : Array {
- return Array (4) {
- ((this shr (24 - (it * 8))) and 0xFFU).toUByte()
- }
-}
-
-fun UInt.toLittleEndianTypedUByteArray() : Array {
- return Array (4) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-
-fun UInt.toLittleEndianUByteArray() : UByteArray {
- return UByteArray (4) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-// UInt / Array utils
-
-fun ULong.toBigEndianUByteArray() : Array {
- return Array (8) {
- ((this shr (56 - (it * 8))) and 0xFFU).toUByte()
- }
-}
-
-fun ULong.toLittleEndianTypedUByteArray() : Array {
- return Array (8) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-
-fun ULong.toLittleEndianUByteArray() :UByteArray {
- return UByteArray (8) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-
-fun Array.fromLittleEndianArrayToULong() : ULong {
- if (this.size > 8) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var ulong = this.foldIndexed(0UL) { index, acc, uByte -> acc or (uByte.toULong() shl (index * 8))}
- return ulong
-}
-
-
-fun UByteArray.fromLittleEndianArrayToULong() : ULong {
- if (this.size > 8) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var ulong = this.foldIndexed(0UL) { index, acc, uByte -> acc or (uByte.toULong() shl (index * 8))}
- return ulong
-}
-
-fun UByteArray.arrayChunked(sliceSize: Int): List {
- val last = this.size % sliceSize
- val hasLast = last != 0
- val numberOfSlices = this.size / sliceSize
-
-
- val result : MutableList = MutableList(0) { ubyteArrayOf() }
-
- for (i in 0 until numberOfSlices) {
- result.add(this.sliceArray(i * sliceSize until (i + 1) * sliceSize))
- }
- if (hasLast) {
- result.add(this.sliceArray(numberOfSlices * sliceSize until this.size))
- }
-
- return result
-}
-
-
-
-fun Array.fromBigEndianArrayToULong() : ULong {
- if (this.size > 8) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var ulong = this.foldIndexed(0UL) {
- index, acc, uByte ->
- val res = acc or (uByte.toULong() shl (56 - (index * 8)))
- res
-
- }
- return ulong
-}
-
-
-fun Array.fromLittleEndianArrayToUInt() : UInt {
- if (this.size > 4) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var uint = this.foldIndexed(0U) { index, acc, uByte -> acc or (uByte.toUInt() shl (index * 8))}
- return uint
-}
-
-
-fun UByteArray.fromLittleEndianArrayToUInt() : UInt {
- if (this.size > 4) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var uint = this.foldIndexed(0U) { index, acc, uByte -> acc or (uByte.toUInt() shl (index * 8))}
- return uint
-}
-
-
-
-
-
-fun Array.fromBigEndianArrayToUInt() : UInt {
- if (this.size > 4) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var uint = this.foldIndexed(0U) { index, acc, uByte -> acc or (uByte.toUInt() shl (24 - (index * 8))) }
- return uint
-}
-
-
-operator fun UInt.plus(other : UByteArray) : UByteArray {
- return this.toLittleEndianUByteArray() + other
-}
-
-//AES Flatten
-fun Collection.flattenToUByteArray(): UByteArray {
- val result = UByteArray(sumBy { it.size })
- var position = 0
- for (element in this) {
- element.forEach { uByte ->
- result[position] = uByte
- position++
- }
- }
- return result
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/DebugTest.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/DebugTest.kt
deleted file mode 100644
index 07bd5fd..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/DebugTest.kt
+++ /dev/null
@@ -1,13 +0,0 @@
-package com.ionspin.kotlin.crypto
-
-import kotlin.test.Test
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2020
- */
-class DebugTest {
-
-
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/SRNGTest.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/SRNGTest.kt
deleted file mode 100644
index 0e2235f..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/SRNGTest.kt
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.util.testBlocking
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-class SRNGTest {
- @Test
- fun testSrng() = testBlocking {
- CryptoInitializerDelegated.initialize()
- //Just a sanity test, need to add better srng tests.
- val randomBytes1 = SRNG.getRandomBytes(10)
- val randomBytes2 = SRNG.getRandomBytes(10)
- assertTrue { !randomBytes1.contentEquals(randomBytes2) }
- }
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Test.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Test.kt
deleted file mode 100644
index f9006e6..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Test.kt
+++ /dev/null
@@ -1,240 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.ionspin.kotlin.crypto.CryptoInitializerDelegated
-import com.ionspin.kotlin.crypto.Initializer
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import com.ionspin.kotlin.crypto.util.testBlocking
-import kotlin.test.Ignore
-import kotlin.test.Test
-import kotlin.test.assertFails
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jun-2020
- */
-class XChaCha20Poly1305Test {
-
-
- @Test
- fun xChaCha20Poly1305() = testBlocking {
- CryptoInitializerDelegated.initialize()
-
- assertTrue {
- val message = ("Ladies and Gentlemen of the class of '99: If I could offer you " +
- "only one tip for the future, sunscreen would be it.").encodeToUByteArray()
-
- val associatedData = ubyteArrayOf(
- 0x50U, 0x51U, 0x52U, 0x53U, 0xc0U, 0xc1U, 0xc2U, 0xc3U, 0xc4U, 0xc5U, 0xc6U, 0xc7U
- )
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU,
- )
-
- val nonce = ubyteArrayOf(
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x57U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x6dU, 0x17U, 0x9dU, 0x3eU, 0x83U, 0xd4U, 0x3bU,
- 0x95U, 0x76U, 0x57U, 0x94U, 0x93U, 0xc0U, 0xe9U, 0x39U,
- 0x57U, 0x2aU, 0x17U, 0x00U, 0x25U, 0x2bU, 0xfaU, 0xccU,
- 0xbeU, 0xd2U, 0x90U, 0x2cU, 0x21U, 0x39U, 0x6cU, 0xbbU,
- 0x73U, 0x1cU, 0x7fU, 0x1bU, 0x0bU, 0x4aU, 0xa6U, 0x44U,
- 0x0bU, 0xf3U, 0xa8U, 0x2fU, 0x4eU, 0xdaU, 0x7eU, 0x39U,
- 0xaeU, 0x64U, 0xc6U, 0x70U, 0x8cU, 0x54U, 0xc2U, 0x16U,
- 0xcbU, 0x96U, 0xb7U, 0x2eU, 0x12U, 0x13U, 0xb4U, 0x52U,
- 0x2fU, 0x8cU, 0x9bU, 0xa4U, 0x0dU, 0xb5U, 0xd9U, 0x45U,
- 0xb1U, 0x1bU, 0x69U, 0xb9U, 0x82U, 0xc1U, 0xbbU, 0x9eU,
- 0x3fU, 0x3fU, 0xacU, 0x2bU, 0xc3U, 0x69U, 0x48U, 0x8fU,
- 0x76U, 0xb2U, 0x38U, 0x35U, 0x65U, 0xd3U, 0xffU, 0xf9U,
- 0x21U, 0xf9U, 0x66U, 0x4cU, 0x97U, 0x63U, 0x7dU, 0xa9U,
- 0x76U, 0x88U, 0x12U, 0xf6U, 0x15U, 0xc6U, 0x8bU, 0x13U,
- 0xb5U, 0x2eU, 0xc0U, 0x87U, 0x59U, 0x24U, 0xc1U, 0xc7U,
- 0x98U, 0x79U, 0x47U, 0xdeU, 0xafU, 0xd8U, 0x78U, 0x0aU,
- 0xcfU, 0x49U
- )
- val encrypted = XChaCha20Poly1305Delegated.encrypt(key, nonce, message, associatedData)
- encrypted.hexColumsPrint()
- val decrypted = XChaCha20Poly1305Delegated.decrypt(key, nonce, encrypted, associatedData)
- println("Decrypted")
- decrypted.hexColumsPrint()
- println("----------")
- encrypted.contentEquals(expected) && decrypted.contentEquals(message)
- }
-
- assertTrue {
- val message = ubyteArrayOf(
- 0x00U
- )
- val associatedData = ubyteArrayOf(
- 0x00U
- )
- val key = ubyteArrayOf(
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- )
-
- val nonce = ubyteArrayOf(
- 0x00U, 0x01U, 0x02U, 0x03U, 0x04U, 0x05U, 0x06U, 0x07U, 0x08U, 0x09U, 0x0aU, 0x0bU,
- 0x0cU, 0x0dU, 0x0eU, 0x0fU, 0x10U, 0x11U, 0x12U, 0x13U, 0x14U, 0x15U, 0x16U, 0x17U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x3bU, 0x8aU, 0xd7U, 0xa1U, 0x9dU, 0xe8U, 0xc4U, 0x55U,
- 0x84U, 0x6fU, 0xfcU, 0x75U, 0x31U, 0xbfU, 0x0cU, 0x2dU
- )
- val encrypted = XChaCha20Poly1305Delegated.encrypt(key, nonce, message, associatedData)
- val decrypted = XChaCha20Poly1305Delegated.decrypt(key, nonce, encrypted, associatedData)
-
- encrypted.contentEquals(expected) && decrypted.contentEquals(message)
- }
-
-
- }
-
- @Ignore() //"Will fail because nonce is not a parameter any more"
- @Test
- fun updateableXChaCha20Poly1305() {
- assertTrue {
- val message = ("Ladies and Gentlemen of the class of '99: If I could offer you " +
- "only one tip for the future, sunscreen would be it.").encodeToUByteArray()
-
- val associatedData = ubyteArrayOf(
- 0x50U, 0x51U, 0x52U, 0x53U, 0xc0U, 0xc1U, 0xc2U, 0xc3U, 0xc4U, 0xc5U, 0xc6U, 0xc7U
- )
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU,
- )
-
- val nonce = ubyteArrayOf(
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x57U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x6dU, 0x17U, 0x9dU, 0x3eU, 0x83U, 0xd4U, 0x3bU,
- 0x95U, 0x76U, 0x57U, 0x94U, 0x93U, 0xc0U, 0xe9U, 0x39U,
- 0x57U, 0x2aU, 0x17U, 0x00U, 0x25U, 0x2bU, 0xfaU, 0xccU,
- 0xbeU, 0xd2U, 0x90U, 0x2cU, 0x21U, 0x39U, 0x6cU, 0xbbU,
- 0x73U, 0x1cU, 0x7fU, 0x1bU, 0x0bU, 0x4aU, 0xa6U, 0x44U,
- 0x0bU, 0xf3U, 0xa8U, 0x2fU, 0x4eU, 0xdaU, 0x7eU, 0x39U,
- 0xaeU, 0x64U, 0xc6U, 0x70U, 0x8cU, 0x54U, 0xc2U, 0x16U,
- 0xcbU, 0x96U, 0xb7U, 0x2eU, 0x12U, 0x13U, 0xb4U, 0x52U,
- 0x2fU, 0x8cU, 0x9bU, 0xa4U, 0x0dU, 0xb5U, 0xd9U, 0x45U,
- 0xb1U, 0x1bU, 0x69U, 0xb9U, 0x82U, 0xc1U, 0xbbU, 0x9eU,
- 0x3fU, 0x3fU, 0xacU, 0x2bU, 0xc3U, 0x69U, 0x48U, 0x8fU,
- 0x76U, 0xb2U, 0x38U, 0x35U, 0x65U, 0xd3U, 0xffU, 0xf9U,
- 0x21U, 0xf9U, 0x66U, 0x4cU, 0x97U, 0x63U, 0x7dU, 0xa9U,
- 0x76U, 0x88U, 0x12U, 0xf6U, 0x15U, 0xc6U, 0x8bU, 0x13U,
- 0xb5U, 0x2eU, 0xc0U, 0x87U, 0x59U, 0x24U, 0xc1U, 0xc7U,
- 0x98U, 0x79U, 0x47U, 0xdeU, 0xafU, 0xd8U, 0x78U, 0x0aU,
- 0xcfU, 0x49U
- )
-// val xChaChaPoly = XChaCha20Poly1305Delegated(key, associatedData)
-// val firstChunk = xChaChaPoly.encrypt(message)
-// val finalChunk = xChaChaPoly.finishEncryption().first
-// val result = firstChunk + finalChunk
-
-// result.contentEquals(expected)
- 1 == 1
- }
-
- assertTrue {
- val message = ubyteArrayOf(
- 0x00U
- )
- val associatedData = ubyteArrayOf(
- 0x00U
- )
- val key = ubyteArrayOf(
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- )
-
- val nonce = ubyteArrayOf(
- 0x00U, 0x01U, 0x02U, 0x03U, 0x04U, 0x05U, 0x06U, 0x07U, 0x08U, 0x09U, 0x0aU, 0x0bU,
- 0x0cU, 0x0dU, 0x0eU, 0x0fU, 0x10U, 0x11U, 0x12U, 0x13U, 0x14U, 0x15U, 0x16U, 0x17U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x3bU, 0x8aU, 0xd7U, 0xa1U, 0x9dU, 0xe8U, 0xc4U, 0x55U,
- 0x84U, 0x6fU, 0xfcU, 0x75U, 0x31U, 0xbfU, 0x0cU, 0x2dU
- )
-// val xChaChaPoly = XChaCha20Poly1305Delegated(key, associatedData)
-// val firstChunk = xChaChaPoly.encrypt(message)
-// val finalChunk = xChaChaPoly.finishEncryption().first
-// val result = firstChunk + finalChunk
-// result.contentEquals(expected)
- 1 == 1
- }
-
-
- }
-
- @Test
- fun testStreamingImpl() = testBlocking {
- Initializer.initialize()
- val key = UByteArray(32) { 0U }
- val state = ubyteArrayOf(
- 0x2DU, 0xDBU, 0xC7U, 0xB2U, 0x03U, 0xBCU, 0xC3U, 0x22U, 0xBDU, 0x0CU, 0xBAU, 0x82U, 0xADU, 0x77U, 0x79U, 0x44U,
- 0xE6U, 0x8FU, 0xA9U, 0x94U, 0x89U, 0xB1U, 0xDFU, 0xBEU, 0x00U, 0x9FU, 0x69U, 0xECU, 0x21U, 0x88U, 0x47U, 0x55U,
- 0x01U, 0x00U, 0x00U, 0x00U, 0xC5U, 0x55U, 0x06U, 0x38U, 0xEBU, 0xA3U, 0x12U, 0x7BU, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U,
- )
- val header = ubyteArrayOf(
- 0x49U, 0x62U, 0x22U, 0x03U, 0xB7U, 0x46U, 0x11U, 0x97U, 0x8FU, 0x46U, 0x4AU, 0x3BU, 0x2FU, 0x2AU, 0x81U, 0x03U,
- 0xC5U, 0x55U, 0x06U, 0x38U, 0xEBU, 0xA3U, 0x12U, 0x7BU,
- )
- val expected = ubyteArrayOf(
- 0xAFU, 0xD3U, 0x2DU, 0x59U, 0xB8U, 0xC4U, 0x66U, 0x2EU, 0x47U, 0x29U, 0xC6U, 0xF9U, 0x93U, 0x4BU, 0x09U, 0x27U,
- 0x24U, 0xDDU, 0xF3U, 0x05U, 0x48U, 0x94U, 0x67U, 0x10U, 0x00U, 0x21U, 0x85U, 0x22U, 0x96U, 0x3CU, 0xCEU, 0x8EU,
- 0xB7U, 0x53U, 0x9DU, 0x46U, 0xF5U, 0x3CU, 0x5EU, 0x48U, 0x9BU, 0x8CU, 0x13U, 0xB7U, 0x28U, 0x6BU, 0xB3U, 0x6CU,
- 0x3AU, 0x04U, 0xB7U, 0x25U, 0xB9U, 0x50U, 0x45U, 0x08U, 0x0BU, 0x89U, 0xA2U, 0x0FU, 0x70U, 0xCCU, 0x60U, 0x1BU,
- 0xC3U, 0x17U, 0x35U, 0x9FU, 0xAEU, 0x82U, 0x51U, 0x43U, 0x1BU, 0x9DU, 0x53U, 0x9EU, 0xE2U, 0xAFU, 0x20U, 0x1FU,
- 0xFDU, 0x03U, 0x59U, 0x11U, 0x51U, 0x9EU, 0xACU, 0x83U, 0xCDU, 0x78U, 0xD1U, 0xD0U, 0xE5U, 0xD7U, 0x0EU, 0x41U,
- 0xDEU, 0xFBU, 0x5CU, 0x7FU, 0x1CU, 0x26U, 0x32U, 0x2CU, 0x51U, 0xF6U, 0xEFU, 0xC6U, 0x34U, 0xC4U, 0xACU, 0x6CU,
- 0xE8U, 0xF9U, 0x4BU, 0xABU, 0xA3U,
- )
- val encryptor = XChaCha20Poly1305Delegated(key, state, header, false)
- val decryptor = XChaCha20Poly1305Delegated(key, state, header, true)
- val data = UByteArray(100) { 0U }
- val result = encryptor.encrypt(data)
- val decrypted = decryptor.decrypt(result)
- println("Encrypted -----------")
- result.hexColumsPrint()
- println("Encrypted end -----------")
- println("Decrypted -----------")
- decrypted.hexColumsPrint()
- println("Decrypted end -----------")
- assertTrue {
- expected.contentEquals(result) && decrypted.contentEquals(data)
- }
- val messedUpTag = result.copyOf()
- messedUpTag[messedUpTag.size - 3] = 0U
- messedUpTag[messedUpTag.size - 2] = 0U
- messedUpTag[messedUpTag.size - 1] = 0U
- assertFails {
- val decryptorForWrongTag = XChaCha20Poly1305Delegated(key, state, header, true)
- val plaintext = decryptorForWrongTag.decrypt(messedUpTag)
- println("Decrypted with wrong tag -----------")
- plaintext.hexColumsPrint()
- println("Decrypted with wrong tag end -----------")
- }
- }
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bTest.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bTest.kt
deleted file mode 100644
index 1fea8a7..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bTest.kt
+++ /dev/null
@@ -1,46 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-import com.ionspin.kotlin.crypto.Crypto
-import com.ionspin.kotlin.crypto.CryptoPrimitives
-import com.ionspin.kotlin.crypto.Initializer
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.testBlocking
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.BeforeTest
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 09-Jun-2020
- */
-class Blake2bTest {
-
-
-
- @Test
- fun statelessSimpleTest() = testBlocking {
- Initializer.initialize()
- val expected = "a71079d42853dea26e453004338670a53814b78137ffbed07603a41d76a483aa9bc33b582f77d30a65e6f29a89" +
- "6c0411f38312e1d66e0bf16386c86a89bea572"
- val result = CryptoPrimitives.Blake2b.stateless("test".encodeToUByteArray()).toHexString()
-// println("Result: $result")
- assertTrue { result == expected }
- }
-
- //This is a bad test since it's not larger than one block
- //but for now I'm testing that the platform library is being correctly called
- @Test
- fun updateableSimpleTest() = testBlocking {
- Initializer.initialize()
- val expected = "a71079d42853dea26e453004338670a53814b78137ffbed07603a41d76a483aa9bc33b582f77d30a65e6f29a89" +
- "6c0411f38312e1d66e0bf16386c86a89bea572"
- val blake2b = CryptoPrimitives.Blake2b.updateable()
- blake2b.update("t".encodeToUByteArray())
- blake2b.update(("est".encodeToUByteArray()))
- val result = blake2b.digest().toHexString()
-// println("Result: $result")
- assertTrue { result == expected }
- }
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Test.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Test.kt
deleted file mode 100644
index 2068b0f..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Test.kt
+++ /dev/null
@@ -1,46 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.Crypto
-import com.ionspin.kotlin.crypto.CryptoPrimitives
-import com.ionspin.kotlin.crypto.Initializer
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.testBlocking
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.BeforeTest
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 07-Jun-2020
- */
-class Sha256Test {
- @BeforeTest
- fun beforeTest() = testBlocking {
- Initializer.initialize()
- }
-
- @Test
- fun statelessSimpleTest() = testBlocking {
- Initializer.initialize()
- val expected = "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08"
- val result = CryptoPrimitives.Sha256.stateless("test".encodeToUByteArray()).toHexString()
-// println("Result: $result")
- assertTrue { result == expected }
- }
-
- //This is a bad test since it's not larger than one block
- //but for now I'm testing that the platform library is being correctly called
- @Test
- fun updateableSimpleTest() = testBlocking {
- Initializer.initialize()
- val expected = "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08"
- val sha256 = CryptoPrimitives.Sha256.updateable()
- sha256.update("t".encodeToUByteArray())
- sha256.update(("est".encodeToUByteArray()))
- val result = sha256.digest().toHexString()
-// println("Result: $result")
- assertTrue { result == expected }
- }
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Test.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Test.kt
deleted file mode 100644
index 44a0375..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Test.kt
+++ /dev/null
@@ -1,48 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.Crypto
-import com.ionspin.kotlin.crypto.CryptoPrimitives
-import com.ionspin.kotlin.crypto.Initializer
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.testBlocking
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.BeforeTest
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 07-Jun-2020
- */
-class Sha512Test {
- @BeforeTest
- fun beforeTest() = testBlocking {
- Initializer.initialize()
- }
-
- @Test
- fun statelessSimpleTest() = testBlocking {
- Initializer.initialize()
- val expected = "ee26b0dd4af7e749aa1a8ee3c10ae9923f618980772e473f8819a5d4940e0db27ac185f8a0e1d5f84f88bc887fd67" +
- "b143732c304cc5fa9ad8e6f57f50028a8ff"
- val result = CryptoPrimitives.Sha512.stateless("test".encodeToUByteArray()).toHexString()
-// println("Result: $result")
- assertTrue { result == expected }
- }
-
- //This is a bad test since it's not larger than one block
- //but for now I'm testing that the platform library is being correctly called
- @Test
- fun updateableSimpleTest() = testBlocking {
- Initializer.initialize()
- val expected = "ee26b0dd4af7e749aa1a8ee3c10ae9923f618980772e473f8819a5d4940e0db27ac185f8a0e1d5f84f88bc887fd67" +
- "b143732c304cc5fa9ad8e6f57f50028a8ff"
- val sha512 = CryptoPrimitives.Sha512.updateable()
- sha512.update("t".encodeToUByteArray())
- sha512.update(("est".encodeToUByteArray()))
- val result = sha512.digest().toHexString()
-// println("Result: $result")
- assertTrue { result == expected }
- }
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/highlevel/EncryptionTest.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/highlevel/EncryptionTest.kt
deleted file mode 100644
index 9573fcc..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/highlevel/EncryptionTest.kt
+++ /dev/null
@@ -1,50 +0,0 @@
-package com.ionspin.kotlin.crypto.highlevel
-
-import com.ionspin.kotlin.crypto.Crypto
-import com.ionspin.kotlin.crypto.Initializer
-import com.ionspin.kotlin.crypto.SymmetricKey
-import com.ionspin.kotlin.crypto.hash.decodeToString
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import com.ionspin.kotlin.crypto.util.testBlocking
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 09-Jul-2020
- */
-class EncryptionTest {
- @Test
- fun testMultipartEncryption() = testBlocking {
- Initializer.initialize()
- val plaintext = ("pUoR4JVXJUeMKNkt6ZGGzEdTo33ajNGXwXpivBKA0XKs8toGRYI9Eul4bELRDkaQDNhd4vZseEFU" +
- "ojsAn3c9zIifIrMnydSivHVZ2pBtpAQwYoJhYmEsfE0tROGnOwFWyB9K6LRSv1gB3YqKR9VyM8mpRoUM3UCRRjyiX7bnKdCE1" +
- "EiX0myiwcY1nUKTgB3keERWtMU07hX7bCtao5nRvDofSj3o3IInHRQh6opltr5asQwn4m1qn029QF").encodeToUByteArray()
- val associatedData = "Additional data 1".encodeToUByteArray()
- val keyValue = UByteArray(32) { it.toUByte() }
- val key = SymmetricKey(keyValue)
- val encryptor = Crypto.Encryption.createMultipartEncryptor(key)
- val header = encryptor.startEncryption()
- val ciphertext1 = encryptor.encryptPartialData(plaintext.sliceArray(0 until 100), associatedData)
- val ciphertext2 = encryptor.encryptPartialData(plaintext.sliceArray(100 until 200))
- val ciphertext3 = encryptor.encryptPartialData(plaintext.sliceArray(200 until 250))
- //decrypt
- val decryptor = Crypto.Encryption.createMultipartDecryptor(key, header)
- val plaintext1 = decryptor.decryptPartialData(ciphertext1, associatedData)
- val plaintext2 = decryptor.decryptPartialData(ciphertext2)
- val plaintext3 = decryptor.decryptPartialData(ciphertext3)
-
- val combinedPlaintext = plaintext1.data + plaintext2.data + plaintext3.data
- assertTrue {
- plaintext.contentEquals(combinedPlaintext)
- }
- encryptor.cleanup()
- decryptor.cleanup()
-
-
-
-
- }
-}
diff --git a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/util/TestUtil.kt b/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/util/TestUtil.kt
deleted file mode 100644
index 7d938dd..0000000
--- a/multiplatform-crypto-delegated/src/commonTest/kotlin/com/ionspin/kotlin/crypto/util/TestUtil.kt
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.util
-
-import kotlin.coroutines.Continuation
-import kotlin.coroutines.EmptyCoroutineContext
-import kotlin.coroutines.startCoroutine
-
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 20-Jul-2019
- */
-fun testBlocking(block : suspend () -> Unit) {
- val continuation = Continuation(EmptyCoroutineContext) {
- //Do nothing
- if (it.isFailure) {
- throw it.exceptionOrNull()!!
- }
- }
- block.startCoroutine(continuation)
-}
diff --git a/multiplatform-crypto-delegated/src/iosMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto-delegated/src/iosMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/iosTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto-delegated/src/iosTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt
deleted file mode 100644
index 9567243..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt
+++ /dev/null
@@ -1,43 +0,0 @@
-package com.ionspin.kotlin.crypto
-
-import ext.libsodium.com.ionspin.kotlin.crypto.JsSodiumInterface
-import ext.libsodium.com.ionspin.kotlin.crypto.JsSodiumLoader
-/* 1.4-M1 has some weirdness with static/objects, or I'm misusing something, not sure */
-lateinit var sodiumPointer : JsSodiumInterface
-var sodiumLoaded: Boolean = false
-
-fun getSodium() : JsSodiumInterface = sodiumPointer
-
-//fun getSodiumAdvanced() : JsSodiumAdvancedInterface = js("sodiumPointer.libsodium")
-
-fun setSodiumPointer(jsSodiumInterface: JsSodiumInterface) {
- js("sodiumPointer = jsSodiumInterface")
-}
-
-fun getSodiumLoaded() : Boolean = sodiumLoaded
-
-fun setSodiumLoaded(loaded: Boolean) {
- js("sodiumLoaded = loaded")
-}
-
-actual object Initializer {
- private var isPlatformInitialized = false
-
- actual suspend fun initialize() {
- JsSodiumLoader.load()
- isPlatformInitialized = true
- }
-
- actual fun initializeWithCallback(done: () -> Unit) {
- JsSodiumLoader.loadWithCallback {
- isPlatformInitialized = true
- done()
- }
- }
-
- actual fun isInitialized(): Boolean {
- return isPlatformInitialized
- }
-
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsSodiumInterface.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsSodiumInterface.kt
deleted file mode 100644
index b917faf..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsSodiumInterface.kt
+++ /dev/null
@@ -1,60 +0,0 @@
-package ext.libsodium.com.ionspin.kotlin.crypto
-
-
-import org.khronos.webgl.Uint8Array
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 27-May-2020
- */
-interface JsSodiumInterface {
-
- fun randombytes_buf(numberOfBytes: Int): Uint8Array
-
- fun crypto_generichash(hashLength: Int, inputMessage: Uint8Array, key: Uint8Array,): Uint8Array
-
- fun crypto_hash_sha256(message: Uint8Array): Uint8Array
-
- fun crypto_hash_sha512(message: Uint8Array): Uint8Array
-
- //Updateable
-
- fun crypto_generichash_init(key : Uint8Array, hashLength: Int) : dynamic
-
- fun crypto_generichash_update(state: dynamic, inputMessage: Uint8Array)
-
- fun crypto_generichash_final(state: dynamic, hashLength: Int) : Uint8Array
-
-
- fun crypto_hash_sha256_init() : dynamic
-
- fun crypto_hash_sha256_update(state: dynamic, message: Uint8Array)
-
- fun crypto_hash_sha256_final(state: dynamic): Uint8Array
-
- fun crypto_hash_sha512_init() : dynamic
-
- fun crypto_hash_sha512_update(state: dynamic, message: Uint8Array)
-
- fun crypto_hash_sha512_final(state: dynamic): Uint8Array
-
- //XChaCha20Poly1305
- fun crypto_aead_xchacha20poly1305_ietf_encrypt(message: Uint8Array, associatedData: Uint8Array, secretNonce: Uint8Array, nonce: Uint8Array, key: Uint8Array) : Uint8Array
- fun crypto_aead_xchacha20poly1305_ietf_decrypt(secretNonce: Uint8Array, ciphertext: Uint8Array, associatedData: Uint8Array, nonce: Uint8Array, key: Uint8Array) : Uint8Array
-
- //XChaCha20Poly1305
- //encrypt
- fun crypto_secretstream_xchacha20poly1305_init_push(header: Uint8Array) : dynamic
- fun crypto_secretstream_xchacha20poly1305_push(state: dynamic, message: Uint8Array, associatedData: Uint8Array, tag: UByte) : Uint8Array
-
- //decrypt
- fun crypto_secretstream_xchacha20poly1305_init_pull(header: Uint8Array, key: Uint8Array) : dynamic
- fun crypto_secretstream_xchacha20poly1305_pull(state: dynamic, ciphertext: Uint8Array, associatedData: Uint8Array) : dynamic
-
- //util
- fun memzero(array: Uint8Array)
-
-
-
-}
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsSodiumLoader.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsSodiumLoader.kt
deleted file mode 100644
index b445487..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsSodiumLoader.kt
+++ /dev/null
@@ -1,56 +0,0 @@
-package ext.libsodium.com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.getSodiumLoaded
-import com.ionspin.kotlin.crypto.setSodiumPointer
-import com.ionspin.kotlin.crypto.sodiumLoaded
-import ext.libsodium.*
-import kotlin.coroutines.Continuation
-import kotlin.coroutines.suspendCoroutine
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 27-May-2020
- */
-object JsSodiumLoader {
-
- class _EmitJsSodiumFunction {
- init {
- println(::crypto_generichash)
- println(::crypto_hash_sha256)
- println(::crypto_hash_sha512)
- println(::crypto_hash_sha256_init)
- }
-
- }
-
- fun storeSodium(promisedSodium: dynamic, continuation: Continuation) {
- setSodiumPointer(promisedSodium)
- sodiumLoaded = true
- continuation.resumeWith(Result.success(Unit))
- }
-
- suspend fun load() = suspendCoroutine { continuation ->
- console.log(getSodiumLoaded())
- if (!getSodiumLoaded()) {
- val libsodiumModule = js("\$module\$libsodium_wrappers_sumo")
- _libsodiumPromise.then { storeSodium(libsodiumModule, continuation) }
- } else {
- continuation.resumeWith(Result.success(Unit))
- }
- }
-
- fun loadWithCallback(doneCallback: () -> (Unit)) {
- console.log(getSodiumLoaded())
- if (!getSodiumLoaded()) {
- val libsodiumModule = js("\$module\$libsodium_wrappers_sumo")
- _libsodiumPromise.then {
- setSodiumPointer(libsodiumModule)
- sodiumLoaded = true
- doneCallback.invoke()
- }
- } else {
- doneCallback.invoke()
- }
- }
-}
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsUtil.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsUtil.kt
deleted file mode 100644
index 1c001d2..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/JsUtil.kt
+++ /dev/null
@@ -1,27 +0,0 @@
-package ext.libsodium.com.ionspin.kotlin.crypto
-
-import org.khronos.webgl.Uint8Array
-import org.khronos.webgl.get
-import org.khronos.webgl.set
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 25-Jun-2020
- *
- * TODO investigate using unsafe cast
- */
-fun UByteArray.toUInt8Array() : Uint8Array {
- val uint8Result = Uint8Array(toByteArray().toTypedArray())
- return uint8Result
-}
-
-
-fun Uint8Array.toUByteArray() : UByteArray {
- val result = UByteArray(length)
- for (i in 0 until length) {
- result[i] = get(i).toUByte()
- }
-
- return result
-}
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index 862aae9..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import org.khronos.webgl.get
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-actual object SRNG {
- var counter = 0
-
- actual fun getRandomBytes(amount: Int): UByteArray {
- val randomBytes = getSodium().randombytes_buf(amount)
- val randomBytesUByteArray = UByteArray(amount) {
- 0U
- }
- for (i in 0 until amount) {
- js("""
- randomBytesUByteArray[i] = randomBytes[i]
- """)
- }
- return randomBytesUByteArray
- }
-
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt
deleted file mode 100644
index faeea44..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt
+++ /dev/null
@@ -1,130 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.ionspin.kotlin.crypto.InvalidTagException
-import com.ionspin.kotlin.crypto.getSodium
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import ext.libsodium.com.ionspin.kotlin.crypto.toUByteArray
-import ext.libsodium.com.ionspin.kotlin.crypto.toUInt8Array
-import org.khronos.webgl.Uint8Array
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 25-Jun-2020
- */
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jun-2020
- */
-actual class XChaCha20Poly1305Delegated internal actual constructor() {
- actual companion object {
- actual fun encrypt(
- key: UByteArray,
- nonce: UByteArray,
- message: UByteArray,
- associatedData: UByteArray
- ): UByteArray {
- val encrypted = getSodium().crypto_aead_xchacha20poly1305_ietf_encrypt(
- message.toUInt8Array(),
- associatedData.toUInt8Array(),
- Uint8Array(0),
- nonce.toUInt8Array(),
- key.toUInt8Array()
- )
- return encrypted.toUByteArray()
- }
-
- actual fun decrypt(
- key: UByteArray,
- nonce: UByteArray,
- ciphertext: UByteArray,
- associatedData: UByteArray
- ): UByteArray {
- val decrypted = getSodium().crypto_aead_xchacha20poly1305_ietf_decrypt(
- Uint8Array(0),
- ciphertext.toUInt8Array(),
- associatedData.toUInt8Array(),
- nonce.toUInt8Array(),
- key.toUInt8Array()
- )
- return decrypted.toUByteArray()
- }
- }
-
- var state : dynamic = null
- var isInitialized = false
- var isEncryptor = false
-
- actual fun initializeForEncryption(key: UByteArray) : UByteArray {
- println("Initializaing for encryption")
- val stateAndHeader = getSodium().crypto_secretstream_xchacha20poly1305_init_push(key.toUInt8Array())
- state = stateAndHeader.state
- val header = stateAndHeader.header as Uint8Array
- console.log(state)
- console.log(header)
- println("Done initializaing for encryption")
- isInitialized = true
- isEncryptor = true
- return header.toUByteArray()
- }
-
- actual fun initializeForDecryption(key: UByteArray, header: UByteArray) {
- println("Initializing for decryption")
- header.hexColumsPrint()
- state = getSodium().crypto_secretstream_xchacha20poly1305_init_pull(header.toUInt8Array(), key.toUInt8Array())
- console.log(state)
- isInitialized = true
- isEncryptor = false
- }
-
- internal actual constructor(
- key: UByteArray,
- testState: UByteArray,
- testHeader: UByteArray,
- isDecryptor: Boolean
- ) : this() {
- state = getSodium().crypto_secretstream_xchacha20poly1305_init_pull(testHeader.toUInt8Array(), key.toUInt8Array())
- console.log(state)
- println("Done initializaing test state")
- isInitialized = true
- isEncryptor = !isDecryptor
- }
-
- actual fun encrypt(data: UByteArray, associatedData: UByteArray): UByteArray {
- if (!isInitialized) {
- throw RuntimeException("Not initalized!")
- }
- if (!isEncryptor) {
- throw RuntimeException("Initialized as decryptor, attempted to use as encryptor")
- }
- val encrypted = getSodium().crypto_secretstream_xchacha20poly1305_push(state, data.toUInt8Array(), associatedData.toUInt8Array(), 0U)
- return encrypted.toUByteArray()
- }
-
- actual fun decrypt(data: UByteArray, associatedData: UByteArray): UByteArray {
- if (!isInitialized) {
- throw RuntimeException("Not initalized!")
- }
- if (isEncryptor) {
- throw RuntimeException("Initialized as encryptor, attempted to use as decryptor")
- }
- val decryptedWithTag = getSodium().crypto_secretstream_xchacha20poly1305_pull(state, data.toUInt8Array(), associatedData.toUInt8Array())
- val decrypted = decryptedWithTag.message as Uint8Array
- val validTag = decryptedWithTag.tag
-
- if (validTag != 0U) {
- println("Tag validation failed")
- throw InvalidTagException()
- }
- return decrypted.toUByteArray()
- }
-
- actual fun cleanup() {
- //TODO JS cleanup
- }
-
-
-
-}
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
deleted file mode 100644
index fa53403..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
+++ /dev/null
@@ -1,60 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-import com.ionspin.kotlin.crypto.getSodium
-import org.khronos.webgl.Uint8Array
-import org.khronos.webgl.get
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jul-2019
- */
-
-
-actual class Blake2bDelegated actual constructor(key: UByteArray?, val hashLength: Int) : Blake2bMultipart {
- override val MAX_HASH_BYTES: Int = 64
-
-
- val state : dynamic
-
- init {
- state = getSodium().crypto_generichash_init(
- Uint8Array(key?.toByteArray()?.toTypedArray() ?: arrayOf()),
- hashLength
- )
- }
-
- override fun update(data: UByteArray) {
- getSodium().crypto_generichash_update(state, Uint8Array(data.toByteArray().toTypedArray()))
- }
-
- override fun digest(): UByteArray {
- val hashed = getSodium().crypto_generichash_final(state, hashLength)
- val hash = UByteArray(hashLength)
- for (i in 0 until hashLength) {
- hash[i] = hashed[i].toUByte()
- }
- return hash
- }
-
-}
-
-
-
-actual object Blake2bDelegatedStateless : Blake2b {
- override val MAX_HASH_BYTES: Int = 64
-
- override fun digest(inputMessage: UByteArray, key: UByteArray, hashLength: Int): UByteArray {
- val hashed = getSodium().crypto_generichash(hashLength,
- Uint8Array(inputMessage.toByteArray().toTypedArray()),
- Uint8Array(key.toByteArray().toTypedArray())
- )
- val hash = UByteArray(hashLength)
- for (i in 0 until hashLength) {
- hash[i] = hashed[i].toUByte()
- }
- return hash
- }
-
-
-}
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
deleted file mode 100644
index 935e18a..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
+++ /dev/null
@@ -1,49 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.getSodium
-
-import org.khronos.webgl.Uint8Array
-import org.khronos.webgl.get
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-actual class Sha256Delegated : Sha256 {
-
- val state : dynamic
-
- init {
- state = getSodium().crypto_hash_sha256_init()
- }
-
- override fun update(data: UByteArray) {
- getSodium().crypto_hash_sha256_update(state, Uint8Array(data.toByteArray().toTypedArray()))
- }
-
- override fun digest(): UByteArray {
- val hashed = getSodium().crypto_hash_sha256_final(state)
- val hash = UByteArray(Sha256StatelessDelegated.MAX_HASH_BYTES)
- console.log(hashed)
- for (i in 0 until Sha256StatelessDelegated.MAX_HASH_BYTES) {
- hash[i] = hashed[i].toUByte()
- }
- return hash
- }
-
-}
-
-actual object Sha256StatelessDelegated : StatelessSha256 {
-
- override fun digest(inputMessage: UByteArray): UByteArray {
- val hashed = getSodium().crypto_hash_sha256(Uint8Array(inputMessage.toByteArray().toTypedArray()))
- val hash = UByteArray(MAX_HASH_BYTES)
- for (i in 0 until MAX_HASH_BYTES) {
- hash[i] = hashed[i].toUByte()
- }
- return hash
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
deleted file mode 100644
index 552932b..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
+++ /dev/null
@@ -1,47 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.getSodium
-
-import org.khronos.webgl.Uint8Array
-import org.khronos.webgl.get
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-actual class Sha512Delegated : Sha512Multipart {
- val state : dynamic
-
- init {
- state = getSodium().crypto_hash_sha512_init()
- }
-
- override fun update(data: UByteArray) {
- getSodium().crypto_hash_sha512_update(state, Uint8Array(data.toByteArray().toTypedArray()))
- }
-
- override fun digest(): UByteArray {
- val hashed = getSodium().crypto_hash_sha512_final(state)
- val hash = UByteArray(Sha512StatelessDelegated.MAX_HASH_BYTES)
- for (i in 0 until Sha512StatelessDelegated.MAX_HASH_BYTES) {
- hash[i] = hashed[i].toUByte()
- }
- return hash
- }
-
-}
-
-actual object Sha512StatelessDelegated : Sha512 {
-
- override fun digest(inputMessage: UByteArray): UByteArray {
- val hashed = getSodium().crypto_hash_sha512(Uint8Array(inputMessage.toByteArray().toTypedArray()))
- val hash = UByteArray(Sha512StatelessDelegated.MAX_HASH_BYTES)
- for (i in 0 until Sha512StatelessDelegated.MAX_HASH_BYTES) {
- hash[i] = hashed[i].toUByte()
- }
- return hash
- }
-}
diff --git a/multiplatform-crypto-delegated/src/jsMain/kotlin/libsodium.kt b/multiplatform-crypto-delegated/src/jsMain/kotlin/libsodium.kt
deleted file mode 100644
index f37c329..0000000
--- a/multiplatform-crypto-delegated/src/jsMain/kotlin/libsodium.kt
+++ /dev/null
@@ -1,28 +0,0 @@
-@file:JsModule("libsodium-wrappers-sumo")
-@file:JsNonModule
-package ext.libsodium
-
-import org.khronos.webgl.Uint8Array
-import kotlin.js.Promise
-
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 25-May-2020
- */
-
-@JsName("ready")
-external val _libsodiumPromise : Promise
-
-external fun crypto_generichash(hashLength: Int, inputMessage: Uint8Array) : Uint8Array
-
-external fun crypto_hash_sha256(message: Uint8Array) : Uint8Array
-external fun crypto_hash_sha512(message: Uint8Array) : Uint8Array
-
-external fun crypto_hash_sha256_init(): dynamic
-
-
-
-
-
diff --git a/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/crypto/SRNGJsTest.kt b/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/crypto/SRNGJsTest.kt
deleted file mode 100644
index 9324d37..0000000
--- a/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/crypto/SRNGJsTest.kt
+++ /dev/null
@@ -1,52 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.util.testBlocking
-import ext.libsodium.com.ionspin.kotlin.crypto.JsSodiumLoader
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 05-Jan-2020
- */
-
-class SRNGJsTest {
-
- @Test
- fun testJsSrng() = testBlocking {
- JsSodiumLoader.load()
- val bytes1 = SRNG.getRandomBytes(10)
- val bytes2 = SRNG.getRandomBytes(10)
-// println("BYTES1\n")
-// bytes1.forEach {
-// print(it.toString(16).padStart(2, '0'))
-// }
-// println("BYTES2\n")
-// bytes2.forEach {
-// print(it.toString(16).padStart(2, '0'))
-// }
- assertTrue {
- !bytes1.contentEquals(bytes2) &&
- bytes1.size == 10 &&
- bytes2.size == 10
- }
-
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt b/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt
deleted file mode 100644
index a366756..0000000
--- a/multiplatform-crypto-delegated/src/jsTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.util
-//
-//import kotlinx.coroutines.GlobalScope
-//import kotlinx.coroutines.promise
-//
-//
-///**
-// * Created by Ugljesa Jovanovic
-// * ugljesa.jovanovic@ionspin.com
-// * on 20-Jul-2019
-// */
-//actual fun testBlocking(block: suspend ()-> Unit) : dynamic = GlobalScope.promise { block() }
diff --git a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt b/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt
deleted file mode 100644
index 082ea90..0000000
--- a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt
+++ /dev/null
@@ -1,25 +0,0 @@
-package com.ionspin.kotlin.crypto
-
-import com.goterl.lazycode.lazysodium.SodiumJava
-
-actual object Initializer {
- private var isPlatformInitialized = false
-
- lateinit var sodium : SodiumJava
- actual suspend fun initialize() {
- sodium = SodiumJava()
- isPlatformInitialized = true
- }
-
- actual fun initializeWithCallback(done: () -> Unit) {
- sodium = SodiumJava()
- isPlatformInitialized = true
- done()
- }
-
- actual fun isInitialized(): Boolean {
- return isPlatformInitialized
- }
-
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index 3d50e6f..0000000
--- a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import java.security.SecureRandom
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-
-actual object SRNG {
- val secureRandom = SecureRandom()
- actual fun getRandomBytes(amount: Int): UByteArray {
- val byteArray = ByteArray(amount)
- secureRandom.nextBytes(byteArray)
- return byteArray.asUByteArray()
- }
-}
diff --git a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt b/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt
deleted file mode 100644
index cb2cdfe..0000000
--- a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt
+++ /dev/null
@@ -1,142 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.goterl.lazycode.lazysodium.SodiumJava
-import com.goterl.lazycode.lazysodium.interfaces.SecretStream
-import com.ionspin.kotlin.crypto.InvalidTagException
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jun-2020
- */
-actual class XChaCha20Poly1305Delegated internal actual constructor() {
- actual companion object {
- actual fun encrypt(
- key: UByteArray,
- nonce: UByteArray,
- message: UByteArray,
- associatedData: UByteArray
- ): UByteArray {
- val ciphertext = ByteArray(message.size + 16)
- SodiumJava().crypto_aead_xchacha20poly1305_ietf_encrypt(
- ciphertext,
- longArrayOf(ciphertext.size.toLong()),
- message.toByteArray(),
- message.size.toLong(),
- associatedData.toByteArray(),
- associatedData.size.toLong(),
- null,
- nonce.toByteArray(),
- key.toByteArray()
-
- )
- return ciphertext.asUByteArray()
- }
-
- actual fun decrypt(
- key: UByteArray,
- nonce: UByteArray,
- ciphertext: UByteArray,
- associatedData: UByteArray
- ): UByteArray {
- val message = ByteArray(ciphertext.size - 16)
- SodiumJava().crypto_aead_xchacha20poly1305_ietf_decrypt(
- message,
- longArrayOf(ciphertext.size.toLong()),
- null,
- ciphertext.toByteArray(),
- ciphertext.size.toLong(),
- associatedData.toByteArray(),
- associatedData.size.toLong(),
- nonce.toByteArray(),
- key.toByteArray()
-
- )
- return message.asUByteArray()
- }
- }
-
- val state : SecretStream.State = SecretStream.State()
- val sodium = SodiumJava()
-
- var isInitialized = false
- var isEncryptor = false
-
- internal actual constructor(
- key: UByteArray,
- testState: UByteArray,
- testHeader: UByteArray,
- isDecryptor: Boolean
- ) : this() {
- state.k = testState.sliceArray(0 until 32).toByteArray()
- state.nonce = testState.sliceArray(32 until 44).toByteArray()
- isInitialized = true
- isEncryptor = !isDecryptor
- }
-
- actual fun initializeForEncryption(key: UByteArray) : UByteArray {
- val header = UByteArray(24)
- sodium.crypto_secretstream_xchacha20poly1305_init_push(state, header.asByteArray(), key.asByteArray())
- isInitialized = true
- isEncryptor = true
- return header
- }
-
- actual fun initializeForDecryption(key: UByteArray, header: UByteArray) {
- sodium.crypto_secretstream_xchacha20poly1305_init_pull(state, header.asByteArray(), key.asByteArray())
- isInitialized = true
- isEncryptor = false
- }
-
- actual fun encrypt(data: UByteArray, associatedData: UByteArray): UByteArray {
- if (!isInitialized) {
- throw RuntimeException("Not initalized!")
- }
- if (!isEncryptor) {
- throw RuntimeException("Initialized as decryptor, attempted to use as encryptor")
- }
- val ciphertext = ByteArray(1 + data.size + 16)
- sodium.crypto_secretstream_xchacha20poly1305_push(
- state, ciphertext, null,
- data.asByteArray(), data.size.toLong(),
- associatedData.asByteArray(), associatedData.size.toLong(),
- 0
- )
- return ciphertext.asUByteArray()
- }
-
- actual fun decrypt(data: UByteArray, associatedData: UByteArray): UByteArray {
- if (!isInitialized) {
- throw RuntimeException("Not initalized!")
- }
- if (isEncryptor) {
- throw RuntimeException("Initialized as encryptor, attempted to use as decryptor")
- }
- val plaintext = ByteArray(data.size - 17)
-
- val validTag = sodium.crypto_secretstream_xchacha20poly1305_pull(
- state, plaintext, null,
- null,
- data.asByteArray(),
- (data.size).toLong(),
- associatedData.asByteArray(),
- associatedData.size.toLong()
- )
- if (validTag != 0) {
- println("Tag validation failed")
- throw InvalidTagException()
- }
- return plaintext.asUByteArray()
-
- }
-
- actual fun cleanup() {
- sodium.sodium_memzero(state.k, 32)
- sodium.sodium_memzero(state.nonce, 12)
- }
-
-
-
-
-}
diff --git a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt b/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
deleted file mode 100644
index bc46c5b..0000000
--- a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
+++ /dev/null
@@ -1,40 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-import com.ionspin.kotlin.crypto.Initializer.sodium
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jul-2019
- */
-
-
-actual class Blake2bDelegated actual constructor(key: UByteArray?, val hashLength: Int) : Blake2bMultipart {
-
- val state = ByteArray(sodium.crypto_generichash_statebytes())
-
- init {
- sodium.crypto_generichash_init(state,key?.toByteArray() ?: byteArrayOf(), key?.size ?: 0, hashLength)
- }
-
- override fun update(data: UByteArray) {
- sodium.crypto_generichash_update(state, data.toByteArray(), data.size.toLong())
- }
-
- override fun digest(): UByteArray {
- val hashed = ByteArray(hashLength)
- sodium.crypto_generichash_final(state, hashed, hashLength)
- return hashed.asUByteArray()
- }
-
-}
-
-actual object Blake2bDelegatedStateless : Blake2b {
-
-
- override fun digest(inputMessage: UByteArray, key: UByteArray, hashLength: Int): UByteArray {
- val hashed = ByteArray(hashLength)
- sodium.crypto_generichash(hashed, hashed.size, inputMessage.toByteArray(), inputMessage.size.toLong(), key.toByteArray(), key.size)
- return hashed.asUByteArray()
- }
-
-}
diff --git a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt b/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
deleted file mode 100644
index ff8faa9..0000000
--- a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
+++ /dev/null
@@ -1,41 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.goterl.lazycode.lazysodium.interfaces.Hash
-import com.ionspin.kotlin.crypto.Initializer.sodium
-
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-actual class Sha256Delegated actual constructor() : Sha256 {
-
- val state = Hash.State256()
-
- init {
- sodium.crypto_hash_sha256_init(state)
- }
-
- override fun update(data: UByteArray) {
- sodium.crypto_hash_sha256_update(state, data.toByteArray(), data.size.toLong())
- }
-
- override fun digest(): UByteArray {
- val hashed = ByteArray(Sha256Properties.MAX_HASH_BYTES)
- sodium.crypto_hash_sha256_final(state, hashed)
- return hashed.asUByteArray()
- }
-
-}
-
-actual object Sha256StatelessDelegated : StatelessSha256 {
-
- override fun digest(inputMessage: UByteArray): UByteArray {
- val hashed = ByteArray(Sha256Properties.MAX_HASH_BYTES)
- sodium.crypto_hash_sha256(hashed, inputMessage.toByteArray(), inputMessage.size.toLong())
- return hashed.asUByteArray()
- }
-}
diff --git a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt b/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
deleted file mode 100644
index adbb1b4..0000000
--- a/multiplatform-crypto-delegated/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
+++ /dev/null
@@ -1,40 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.goterl.lazycode.lazysodium.interfaces.Hash
-import com.ionspin.kotlin.crypto.Initializer
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-actual class Sha512Delegated : Sha512Multipart {
-
- val state = Hash.State512()
-
- init {
- Initializer.sodium.crypto_hash_sha512_init(state)
- }
-
- override fun update(data: UByteArray) {
- Initializer.sodium.crypto_hash_sha512_update(state, data.toByteArray(), data.size.toLong())
- }
-
- override fun digest(): UByteArray {
- val hashed = ByteArray(Sha512Properties.MAX_HASH_BYTES)
- Initializer.sodium.crypto_hash_sha512_final(state, hashed)
- return hashed.asUByteArray()
- }
-
-}
-
-actual object Sha512StatelessDelegated : Sha512 {
-
- override fun digest(inputMessage: UByteArray): UByteArray {
- val hashed = ByteArray(Sha512Properties.MAX_HASH_BYTES)
- Initializer.sodium.crypto_hash_sha512(hashed, inputMessage.toByteArray(), inputMessage.size.toLong())
- return hashed.asUByteArray()
- }
-}
diff --git a/multiplatform-crypto-delegated/src/jvmTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt b/multiplatform-crypto-delegated/src/jvmTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt
deleted file mode 100644
index 5c561f7..0000000
--- a/multiplatform-crypto-delegated/src/jvmTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.util
-
-import kotlin.coroutines.Continuation
-import kotlin.coroutines.EmptyCoroutineContext
-import kotlin.coroutines.startCoroutine
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 20-Jul-2019
- */
-//actual fun testBlocking(block: suspend () -> Unit) {
-// val continuation = Continuation(EmptyCoroutineContext) {
-// println("Done")
-// }
-// block.startCoroutine(continuation)
-//
-//}
diff --git a/multiplatform-crypto-delegated/src/linuxArm32HfpMain/kotlin/com/ionspin/kotlin/crypto/Placeholder b/multiplatform-crypto-delegated/src/linuxArm32HfpMain/kotlin/com/ionspin/kotlin/crypto/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/linuxArm32HfpTest/kotlin/com/ionspin/kotlin/crypto/Placeholder b/multiplatform-crypto-delegated/src/linuxArm32HfpTest/kotlin/com/ionspin/kotlin/crypto/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/linuxX64Main/kotlin/com/ionspin/kotlin/crypto/Placeholder b/multiplatform-crypto-delegated/src/linuxX64Main/kotlin/com/ionspin/kotlin/crypto/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/linuxX64Main/kotlin/com/ionspin/kotlin/crypto/hash/sha/IntelliJCinteropResolverDebug.kt b/multiplatform-crypto-delegated/src/linuxX64Main/kotlin/com/ionspin/kotlin/crypto/hash/sha/IntelliJCinteropResolverDebug.kt
deleted file mode 100644
index 3d7a4b1..0000000
--- a/multiplatform-crypto-delegated/src/linuxX64Main/kotlin/com/ionspin/kotlin/crypto/hash/sha/IntelliJCinteropResolverDebug.kt
+++ /dev/null
@@ -1,9 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 07-Jun-2020
- */
-import platform.posix.*
-//import cin
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/linuxX64Test/kotlin/com/ionspin/kotlin/crypto/Placeholder b/multiplatform-crypto-delegated/src/linuxX64Test/kotlin/com/ionspin/kotlin/crypto/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto-delegated/src/mingwX64Main/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto-delegated/src/mingwX64Main/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index 1a83ce8..0000000
--- a/multiplatform-crypto-delegated/src/mingwX64Main/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,44 +0,0 @@
-//We'll handle SRNG through libsodium
-///*
-// * Copyright 2019 Ugljesa Jovanovic
-// *
-// * Licensed under the Apache License, Version 2.0 (the "License");
-// * you may not use this file except in compliance with the License.
-// * You may obtain a copy of the License at
-// *
-// * http://www.apache.org/licenses/LICENSE-2.0
-// *
-// * Unless required by applicable law or agreed to in writing, software
-// * distributed under the License is distributed on an "AS IS" BASIS,
-// * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-// * See the License for the specific language governing permissions and
-// * limitations under the License.
-// */
-//
-//package com.ionspin.kotlin.crypto
-//
-//import kotlinx.cinterop.*
-//import platform.windows.*
-//
-///**
-// * Created by Ugljesa Jovanovic
-// * ugljesa.jovanovic@ionspin.com
-// * on 21-Sep-2019
-// */
-//actual object SRNG {
-// private val advapi by lazy { LoadLibraryA("ADVAPI32.DLL")}
-//
-// private val advapiRandom by lazy {
-// GetProcAddress(advapi, "SystemFunction036")?.reinterpret, ULong, Int>>>() ?: error("Failed getting advapi random")
-// }
-//
-// @Suppress("EXPERIMENTAL_UNSIGNED_LITERALS")
-// actual fun getRandomBytes(amount: Int): UByteArray {
-// memScoped {
-// val randArray = allocArray(amount)
-// val pointer = randArray.getPointer(this)
-// val status = advapiRandom(pointer.reinterpret(), amount.convert())
-// return UByteArray(amount) { pointer[it].toUByte() }
-// }
-// }
-//}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/nativeInterop/cinterop/libsodium.def b/multiplatform-crypto-delegated/src/nativeInterop/cinterop/libsodium.def
deleted file mode 100644
index 0b00392..0000000
--- a/multiplatform-crypto-delegated/src/nativeInterop/cinterop/libsodium.def
+++ /dev/null
@@ -1,6 +0,0 @@
-headers = sodium.h
-headerFilter = sodium.h sodium/**
-#staticLibraries = libsodium.a
-#libraryPaths = sodiumWrapper/lib
-#compilerOpts = -I./sodiumWrapper/include
-linkerOpts =
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt b/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt
deleted file mode 100644
index 944c199..0000000
--- a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/Initializer.kt
+++ /dev/null
@@ -1,30 +0,0 @@
-@file:Suppress("VARIABLE_IN_SINGLETON_WITHOUT_THREAD_LOCAL")
-
-package com.ionspin.kotlin.crypto
-
-import libsodium.sodium_init
-import kotlin.native.concurrent.AtomicInt
-
-actual object Initializer {
-
- private var isPlatformInitialized : AtomicInt = AtomicInt(0)
-
- actual suspend fun initialize() {
- if (isPlatformInitialized.compareAndSet(0, 1)) {
- sodium_init()
- }
-
-
- }
-
- actual fun initializeWithCallback(done: () -> Unit) {
- if (isPlatformInitialized.compareAndSet(0, 1)) {
- sodium_init()
- }
- done()
- }
-
- actual fun isInitialized(): Boolean {
- return isPlatformInitialized.value != 0
- }
-}
diff --git a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index 78a112a..0000000
--- a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import kotlinx.cinterop.*
-import libsodium.randombytes_buf
-import platform.posix.*
-//import libsod
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-actual object SRNG {
- @Suppress("EXPERIMENTAL_UNSIGNED_LITERALS")
- actual fun getRandomBytes(amount: Int): UByteArray {
- memScoped {
- val array = allocArray(amount)
- randombytes_buf(array, amount.convert())
- return UByteArray(amount) {
- array[it]
- }
- }
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt b/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt
deleted file mode 100644
index eb7f836..0000000
--- a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Delegated.kt
+++ /dev/null
@@ -1,164 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.ionspin.kotlin.bignum.integer.util.hexColumsPrint
-import com.ionspin.kotlin.crypto.InvalidTagException
-import com.ionspin.kotlin.crypto.util.toPtr
-import kotlinx.cinterop.*
-import libsodium.*
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jun-2020
- */
-actual class XChaCha20Poly1305Delegated internal actual constructor() {
- actual companion object {
- actual fun encrypt(
- key: UByteArray,
- nonce: UByteArray,
- message: UByteArray,
- associatedData: UByteArray
- ): UByteArray {
- val ciphertextLength = message.size + crypto_aead_xchacha20poly1305_IETF_ABYTES.toInt()
- val ciphertext = UByteArray(ciphertextLength)
- val ciphertextPinned = ciphertext.pin()
- crypto_aead_xchacha20poly1305_ietf_encrypt(
- ciphertextPinned.toPtr(),
- ulongArrayOf(ciphertextLength.convert()).toCValues(),
- message.toCValues(),
- message.size.convert(),
- associatedData.toCValues(),
- associatedData.size.convert(),
- null,
- nonce.toCValues(),
- key.toCValues()
- )
- ciphertextPinned.unpin()
- return ciphertext
- }
-
- actual fun decrypt(
- key: UByteArray,
- nonce: UByteArray,
- ciphertext: UByteArray,
- associatedData: UByteArray
- ): UByteArray {
- val messageLength = ciphertext.size - crypto_aead_xchacha20poly1305_IETF_ABYTES.toInt()
- val message = UByteArray(messageLength)
- val messagePinned = message.pin()
- crypto_aead_xchacha20poly1305_ietf_decrypt(
- messagePinned.toPtr(),
- ulongArrayOf(messageLength.convert()).toCValues(),
- null,
- ciphertext.toCValues(),
- ciphertext.size.convert(),
- associatedData.toCValues(),
- associatedData.size.convert(),
- nonce.toCValues(),
- key.toCValues()
- )
- messagePinned.unpin()
- return message
- }
- }
-
- var state =
- sodium_malloc(crypto_secretstream_xchacha20poly1305_state.size.convert())!!
- .reinterpret()
- .pointed
- val header = UByteArray(crypto_secretstream_xchacha20poly1305_HEADERBYTES.toInt()) { 0U }
-
- var isInitialized = false
- var isEncryptor = false
-
- actual internal constructor(
- key: UByteArray,
- testState: UByteArray,
- testHeader: UByteArray,
- isDecryptor: Boolean
- ) : this() {
- val pointer = state.ptr.reinterpret()
- for (i in 0 until crypto_secretstream_xchacha20poly1305_state.size.toInt()) {
- pointer[i] = testState[i]
- }
- println("state after setting-----------")
- state.ptr.readBytes(crypto_secretstream_xchacha20poly1305_state.size.toInt()).asUByteArray().hexColumsPrint()
- println("state after setting-----------")
- println("header after setting-----------")
- testHeader.copyInto(header)
- header.hexColumsPrint()
- println("header after setting-----------")
- isInitialized = true
- isEncryptor = !isDecryptor
- }
-
-
-
- actual fun initializeForEncryption(key: UByteArray) : UByteArray {
- val pinnedHeader = header.pin()
- crypto_secretstream_xchacha20poly1305_init_push(state.ptr, pinnedHeader.toPtr(), key.toCValues())
- println("state-----------")
- state.ptr.readBytes(crypto_secretstream_xchacha20poly1305_state.size.toInt()).asUByteArray().hexColumsPrint()
- println("state-----------")
- println("--------header-----------")
- header.hexColumsPrint()
- println("--------header-----------")
- pinnedHeader.unpin()
- return header
- }
-
- actual fun initializeForDecryption(key: UByteArray, header: UByteArray) {
- crypto_secretstream_xchacha20poly1305_init_pull(state.ptr, header.toCValues(), key.toCValues())
- }
-
-
- actual fun encrypt(data: UByteArray, associatedData: UByteArray): UByteArray {
- val ciphertextWithTag = UByteArray(data.size + crypto_secretstream_xchacha20poly1305_ABYTES.toInt())
- val ciphertextWithTagPinned = ciphertextWithTag.pin()
- crypto_secretstream_xchacha20poly1305_push(
- state.ptr,
- ciphertextWithTagPinned.toPtr(),
- null,
- data.toCValues(),
- data.size.convert(),
- associatedData.toCValues(),
- associatedData.size.convert(),
- 0U,
- )
- println("Encrypt partial")
- ciphertextWithTag.hexColumsPrint()
- println("Encrypt partial end")
- ciphertextWithTagPinned.unpin()
- return ciphertextWithTag
- }
-
- actual fun decrypt(data: UByteArray, associatedData: UByteArray): UByteArray {
- val plaintext = UByteArray(data.size - crypto_secretstream_xchacha20poly1305_ABYTES.toInt())
- val plaintextPinned = plaintext.pin()
- val validTag = crypto_secretstream_xchacha20poly1305_pull(
- state.ptr,
- plaintextPinned.toPtr(),
- null,
- null,
- data.toCValues(),
- data.size.convert(),
- associatedData.toCValues(),
- associatedData.size.convert()
- )
- plaintextPinned.unpin()
- println("tag: $validTag")
- if (validTag != 0) {
- println("Tag validation failed")
- throw InvalidTagException()
- }
- return plaintext
- }
-
- actual fun cleanup() {
- sodium_free(state.ptr)
- }
-
-
-
-
-}
diff --git a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt b/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
deleted file mode 100644
index d819606..0000000
--- a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bDelegated.kt
+++ /dev/null
@@ -1,61 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.blake2b
-import com.ionspin.kotlin.crypto.util.toHexString
-import com.ionspin.kotlin.crypto.util.toPtr
-import kotlinx.cinterop.*
-import libsodium.*
-import platform.posix.free
-import platform.posix.malloc
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jul-2019
- */
-
-
-actual class Blake2bDelegated actual constructor(key: UByteArray?, hashLength: Int) : Blake2bMultipart {
- override val MAX_HASH_BYTES: Int = 64
-
- val requestedHashLength : Int
- val state : crypto_generichash_state
- init {
- requestedHashLength = hashLength
- val allocated = malloc(crypto_generichash_state.size.convert())!!
- state = allocated.reinterpret().pointed
- crypto_generichash_init(state.ptr, key?.run { this.toCValues() }, key?.size?.convert() ?: 0UL.convert(), hashLength.convert())
- }
-
- override fun update(data: UByteArray) {
- crypto_generichash_update(state.ptr, data.toCValues(), data.size.convert())
- }
-
- override fun digest(): UByteArray {
- val hashResult = UByteArray(requestedHashLength)
- val hashResultPinned = hashResult.pin()
- crypto_generichash_final(state.ptr, hashResultPinned.toPtr(), requestedHashLength.convert())
- free(state.ptr)
- return hashResult
- }
-
-}
-
-@Suppress("EXPERIMENTAL_API_USAGE", "EXPERIMENTAL_UNSIGNED_LITERALS")
-actual object Blake2bDelegatedStateless : Blake2b {
-
- override fun digest(inputMessage: UByteArray, key: UByteArray, hashLength: Int): UByteArray {
- val hashResult = UByteArray(MAX_HASH_BYTES)
- val hashResultPinned = hashResult.pin()
- crypto_generichash(
- hashResultPinned.toPtr(),
- hashLength.convert(),
- inputMessage.toCValues(),
- inputMessage.size.convert(),
- key.toCValues(),
- key.size.convert()
- )
- hashResultPinned.unpin()
- return hashResult
-
- }
-
-
-}
diff --git a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt b/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
deleted file mode 100644
index 32c1e5d..0000000
--- a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Delegated.kt
+++ /dev/null
@@ -1,55 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bDelegatedStateless
-import com.ionspin.kotlin.crypto.util.toPtr
-import kotlinx.cinterop.*
-import libsodium.*
-import platform.posix.free
-import platform.posix.malloc
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-actual class Sha256Delegated : Sha256 {
-
- val state : crypto_hash_sha256_state
-
- init {
- val allocated = sodium_malloc(crypto_hash_sha256_state.size.convert())!!
- state = allocated.reinterpret().pointed
- crypto_hash_sha256_init(state.ptr)
- }
-
- override fun update(data: UByteArray) {
- crypto_hash_sha256_update(state.ptr, data.toCValues(), data.size.convert())
- }
-
-
-
- override fun digest(): UByteArray {
- val hashResult = UByteArray(Sha256Properties.MAX_HASH_BYTES)
- val hashResultPinned = hashResult.pin()
- crypto_hash_sha256_final(state.ptr, hashResultPinned.toPtr())
- sodium_free(state.ptr)
- return hashResult
- }
-
-
-
-
-}
-actual object Sha256StatelessDelegated : StatelessSha256 {
-
- override fun digest(inputMessage: UByteArray): UByteArray {
- val hashResult = UByteArray(MAX_HASH_BYTES)
- val hashResultPinned = hashResult.pin()
- crypto_hash_sha256(hashResultPinned.toPtr(), inputMessage.toCValues(), inputMessage.size.convert())
- hashResultPinned.unpin()
- return hashResult
- }
-
-}
diff --git a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt b/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
deleted file mode 100644
index a700b04..0000000
--- a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Delegated.kt
+++ /dev/null
@@ -1,50 +0,0 @@
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.util.toPtr
-import kotlinx.cinterop.*
-import libsodium.*
-import platform.posix.free
-import platform.posix.malloc
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-actual class Sha512Delegated : Sha512Multipart {
- val state : crypto_hash_sha512_state
-
- init {
- val allocated = malloc(crypto_hash_sha512_state.size.convert())!!
- state = allocated.reinterpret().pointed
- crypto_hash_sha512_init(state.ptr)
- }
-
- override fun update(data: UByteArray) {
- crypto_hash_sha512_update(state.ptr, data.toCValues(), data.size.convert())
- }
-
-
-
- override fun digest(): UByteArray {
- val hashResult = UByteArray(Sha512Properties.MAX_HASH_BYTES)
- val hashResultPinned = hashResult.pin()
- crypto_hash_sha512_final(state.ptr, hashResultPinned.toPtr())
- free(state.ptr)
- return hashResult
- }
-
-}
-
-actual object Sha512StatelessDelegated : Sha512 {
-
- override fun digest(inputMessage: UByteArray): UByteArray {
- val hashResult = UByteArray(Sha512StatelessDelegated.MAX_HASH_BYTES)
- val hashResultPinned = hashResult.pin()
- crypto_hash_sha512(hashResultPinned.toPtr(), inputMessage.toCValues(), inputMessage.size.convert())
- hashResultPinned.unpin()
- return hashResult
- }
-}
diff --git a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/util/ConversionUtil.kt b/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/util/ConversionUtil.kt
deleted file mode 100644
index 7a0d892..0000000
--- a/multiplatform-crypto-delegated/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/util/ConversionUtil.kt
+++ /dev/null
@@ -1,13 +0,0 @@
-package com.ionspin.kotlin.crypto.util
-
-import kotlinx.cinterop.CPointer
-import kotlinx.cinterop.Pinned
-import kotlinx.cinterop.UByteVar
-import kotlinx.cinterop.addressOf
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 27-Aug-2020
- */
-fun Pinned.toPtr() : CPointer = addressOf(0)
diff --git a/multiplatform-crypto-delegated/src/nativeTest/kotlin/com/ionspin/kotlin/crypto/HelperTest.kt b/multiplatform-crypto-delegated/src/nativeTest/kotlin/com/ionspin/kotlin/crypto/HelperTest.kt
deleted file mode 100644
index 4bc8bcd..0000000
--- a/multiplatform-crypto-delegated/src/nativeTest/kotlin/com/ionspin/kotlin/crypto/HelperTest.kt
+++ /dev/null
@@ -1,77 +0,0 @@
-package com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.toHexString
-import com.ionspin.kotlin.crypto.util.toPtr
-import kotlinx.cinterop.*
-import libsodium.*
-import platform.posix.free
-import platform.posix.malloc
-import kotlin.test.Ignore
-import kotlin.test.Test
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 13-Jul-2020
- */
-class HelperTest {
- @Ignore //Just used for debugging pure implementation
- @Test
- fun longSha256() {
- for (target in 0L until 10L) {
- generateForRounds256(target)
- }
- for (target in 0L until 16_777_216L step 1_000_000L) {
- generateForRounds256(target)
- }
- generateForRounds256(16_777_216L)
- }
-
- fun generateForRounds256(target: Long) {
- val updateValue =
- "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmno".encodeToUByteArray().toCValues()
- val state = malloc(crypto_hash_sha256_state.size.convert())!!
- .reinterpret()
-
- crypto_hash_sha256_init(state)
- for (i in 0 until target) {
- crypto_hash_sha256_update(state, updateValue, updateValue.size.convert())
- }
- val result = UByteArray(32)
- val resultPinned = result.pin()
- crypto_hash_sha256_final(state, resultPinned.toPtr())
- println("$target to \"${result.toHexString()}\",")
- free(state)
- }
- @Ignore //Just used for debugging pure implementation
- @Test
- fun longSha512() {
-
- for (target in 0L until 10L) {
- generateForRounds512(target)
- }
- for (target in 0L until 16_777_216L step 1_000_000L) {
- generateForRounds512(target)
- }
- generateForRounds512(16_777_216L)
- }
-
- fun generateForRounds512(target: Long) {
- println("Wut")
- val updateValue =
- "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmno".encodeToUByteArray().toCValues()
- val state = malloc(crypto_hash_sha512_state.size.convert())!!
- .reinterpret()
-
- crypto_hash_sha512_init(state)
- for (i in 0 until target) {
- crypto_hash_sha512_update(state, updateValue, updateValue.size.convert())
- }
- val result = UByteArray(32)
- val resultPinned = result.pin()
- crypto_hash_sha512_final(state, resultPinned.toPtr())
- println("$target to \"${result.toHexString()}\",")
- free(state)
- }
-}
diff --git a/multiplatform-crypto-delegated/src/nativeTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt b/multiplatform-crypto-delegated/src/nativeTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt
deleted file mode 100644
index 8101dca..0000000
--- a/multiplatform-crypto-delegated/src/nativeTest/kotlin/com/ionspin/kotlin/crypto/util/testBlocking.kt
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-//package com.ionspin.kotlin.crypto.util
-//
-//import kotlinx.coroutines.CoroutineScope
-//import kotlinx.coroutines.runBlocking
-//
-///**
-// * Created by Ugljesa Jovanovic
-// * ugljesa.jovanovic@ionspin.com
-// * on 20-Jul-2019
-// */
-//actual fun testBlocking(block: suspend () -> Unit) = runBlocking { block() }
diff --git a/multiplatform-crypto-libsodium-bindings/build.gradle.kts b/multiplatform-crypto-libsodium-bindings/build.gradle.kts
index b06227f..7aee1fb 100644
--- a/multiplatform-crypto-libsodium-bindings/build.gradle.kts
+++ b/multiplatform-crypto-libsodium-bindings/build.gradle.kts
@@ -20,6 +20,8 @@
import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget
import org.jetbrains.kotlin.gradle.targets.js.testing.KotlinJsTest
import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest
+import org.gradle.api.tasks.testing.logging.TestExceptionFormat
+import org.jetbrains.dokka.Platform
plugins {
kotlin(PluginsDeps.multiplatform)
@@ -593,18 +595,43 @@ tasks {
dokkaJavadoc {
println("Dokka !")
dokkaSourceSets {
- create("commonMain") {
- displayName = "common"
- platform = "common"
+ named("commonMain") {
+ displayName.set("common")
+ platform.set(Platform.common)
}
}
}
+
+ dokkaHtml {
+ println("Dokka Html!")
+ dokkaSourceSets {
+ named("commonMain") {
+// displayName.set("common")
+// platform.set(Platform.common)
+ moduleDisplayName.set("Kotlin Multiplatform Libsodium Bindings")
+ includes.from(
+ "src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/Aead.md",
+ "src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.md",
+ "src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.md",
+ "src/commonMain/kotlin/com.ionspin.kotlin.crypto/CryptoModule.md")
+ displayName.set("Kotlin multiplatform")
+ }
+ configureEach {
+ if (name != "commonMain") {
+ suppress.set(true)
+ }
+ }
+ }
+ }
if (getHostOsName() == "linux" && getHostArchitecture() == "x86-64") {
val jvmTest by getting(Test::class) {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
+ exceptionFormat = TestExceptionFormat.FULL
+ showStandardStreams = true
+ showStackTraces = true
}
}
@@ -612,14 +639,18 @@ tasks {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
+ exceptionFormat = TestExceptionFormat.FULL
showStandardStreams = true
+ showStackTraces = true
}
}
val jsNodeTest by getting(KotlinJsTest::class) {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
-// showStandardStreams = true
+ exceptionFormat = TestExceptionFormat.FULL
+ showStandardStreams = true
+ showStackTraces = true
}
}
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/CryptoModule.md b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/CryptoModule.md
new file mode 100644
index 0000000..cffee3f
--- /dev/null
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/CryptoModule.md
@@ -0,0 +1,10 @@
+# Module Kotlin Multiplatform Libsodium Bindings
+
+### What
+Kotlin Multiplatform Libsodium Bindings is a library providing kotlin idiomatic API to libsodium implementations on various platforms
+
+### Why
+To provide easy to use cryptographic library, based on a well-known and audited libsodium library. T
+### How
+By using built from source libsodium to provide native implementations, LazySodium (JNA wrapper around libsodium) to provide
+JVM and Android implementations and libsodium.js to provide node and browser implementation
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/Aead.md b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/Aead.md
new file mode 100644
index 0000000..fea6376
--- /dev/null
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/Aead.md
@@ -0,0 +1,28 @@
+# Package com.ionspin.kotlin.crypto.aead
+
+## Authenticated encryption with associated data
+
+This is a form of symmetric encryption, that assures both confidentiality and authenticity of the data to be encrypted as well
+as associated data that will not be encrypted.
+
+In general, it works like this:
+
+Inputs:
+- Message to encrypt and authenticate
+- Key to use for encryption
+- **Unique** nonce
+- Additional data that is not encrypted but also authenticated
+
+Simplified encryption algorithm:
+1. Encrypt a message with key and nonce
+1. Apply MAC algorithm to encrypted message + unencrypted associated data to generate authentication data (tag)
+1. Send the encrypted data + associated data + authentication data + nonce
+
+Simplified decryption algorithm:
+1. Apply MAC algorithm to encrypted message + unencrypted associated data to generate authentication data
+1. If the generated authenticated data, and the received authentication data match, proceed, otherwise sound the alarm and stop.
+1. Decrypt the encrypted data
+1. Return the decrypted data and associated data to the user
+
+
+
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
index 6388806..d5737a0 100644
--- a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
@@ -22,13 +22,52 @@ val crypto_aead_chacha20poly1305_KEYBYTES = 32
val crypto_aead_chacha20poly1305_NPUBBYTES = 8
val crypto_aead_chacha20poly1305_ABYTES = 16
-
+/**
+ * A data class wrapping returned encrypted data and and tag from aead encrypt functions.
+ */
data class AeadEncryptedDataAndTag(val data: UByteArray, val tag: UByteArray)
-class AeadCorrupedOrTamperedDataException() : RuntimeException("MAC validation failed. Data is corrupted or tampered with.")
+/**
+ * An exception thrown when tag generated from received data and key doesn't match the received tag
+ */
+class AeadCorrupedOrTamperedDataException() :
+ RuntimeException("Tag (authentication data) validation failed. Data is corrupted or tampered with.")
+/**
+ * This is a form of symmetric encryption, that assures both confidentiality and authenticity of the data to be encrypted as well
+as associated data that will not be encrypted.
+ *
+ * Offered here are three implementations of (x)ChaCha20-Poly1305 construction:
+ * - ChaCha20Poly1305 - uses 64bit nonce, safe to encrypt
+ * - ChaCha20Poly1305-IETF - uses 96bit nonce (standardised by [RFC8439](https://tools.ietf.org/html/rfc8439)
+ * - XChaCha20Poly1305 - uses 192bit nonce - recommended choice
+ *
+ * The only difference is the size of the nonce, and how is the nonce used.
+ *
+ * (x)ChaCha20 is a streaming cipher develop by Daniel J. Bernstein. He is also the author of Poly1305 a fast Message
+ * Authentication Code system
+ *
+ * Libsodium offers two additional variants for each of the aforementioned variants:
+ * - Combined
+ * - Detached
+ *
+ * Combined mode returns encrypted data and tag as one UByteArray, while detached mode returns them as separate UByteArrays.
+ * To be kotlin idiomatic we are returning detached tag and encrypted data inside a wrapper data class [AeadEncryptedDataAndTag]
+ *
+ * Also provided are key generation convenience functions for each variant. (Which is in practice the same, since the keys
+ * same length for each variant)
+ */
expect object AuthenticatedEncryptionWithAssociatedData {
// X - Ietf
+ /**
+ * Encrypt the message and return encrypted data and tag using xChaChaPoly1305 (192 bit nonce)
+ *
+ * @param message message to encrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a **unique** nonce
+ * @param key secret key
+ * @return encrypted data and tag (in that order)
+ */
fun xChaCha20Poly1305IetfEncrypt(
message: UByteArray,
associatedData: UByteArray,
@@ -36,13 +75,34 @@ expect object AuthenticatedEncryptionWithAssociatedData {
key: UByteArray
): UByteArray
+ /**
+ * Check if authentication data (tag) is correct, then decrypt the message and return decrypted data.
+ * Using xChaChaPoly1305 (192 bit nonce)
+ *
+ * @param ciphertextAndTag message to decrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a nonce used to encrypt the message
+ * @param key secret key
+ * @return decrypted data
+ * @throws AeadCorrupedOrTamperedDataException if authentication data (tag) cannot be verified
+ */
fun xChaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray
+ /**
+ * Encrypt the message and return encrypted data and tag using xChaChaPoly1305 (192 bit nonce) as
+ * separate arrays (but wrapped inside [AeadEncryptedDataAndTag])
+ *
+ * @param message message to encrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a **unique** nonce
+ * @param key secret key
+ * @return encrypted data and tag wrapped inside [AeadEncryptedDataAndTag] data class instance
+ */
fun xChaCha20Poly1305IetfEncryptDetached(
message: UByteArray,
associatedData: UByteArray,
@@ -50,6 +110,18 @@ expect object AuthenticatedEncryptionWithAssociatedData {
key: UByteArray
): AeadEncryptedDataAndTag
+ /**
+ * Check if authentication data (tag) is correct, then decrypt the message and return decrypted data.
+ * Using xChaChaPoly1305 (192 bit nonce)
+ *
+ * @param ciphertext message to decrypt
+ * @param tag authenticatoin data (tag)
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a nonce used to encrypt the message
+ * @param key secret key
+ * @return decrypted data
+ * @throws AeadCorrupedOrTamperedDataException if authentication data (tag) cannot be verified
+ */
fun xChaCha20Poly1305IetfDecryptDetached(
ciphertext: UByteArray,
tag: UByteArray,
@@ -59,21 +131,48 @@ expect object AuthenticatedEncryptionWithAssociatedData {
): UByteArray
// Ietf
-
+ /**
+ * Encrypt the message and return encrypted data and tag using ChaChaPoly1305-IETF (96 bit nonce)
+ *
+ * @param message message to encrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a **unique** nonce
+ * @param key secret key
+ * @return encrypted data and tag (in that order)
+ */
fun chaCha20Poly1305IetfEncrypt(
message: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray
-
+ /**
+ * Check if authentication data (tag) is correct, then decrypt the message and return decrypted data.
+ * Using ChaChaPoly1305-IETF (96 bit nonce)
+ *
+ * @param ciphertextAndTag message to decrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a nonce used to encrypt the message
+ * @param key secret key
+ * @return decrypted data
+ * @throws AeadCorrupedOrTamperedDataException if authentication data (tag) cannot be verified
+ */
fun chaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray
-
+ /**
+ * Encrypt the message and return encrypted data and tag using ChaChaPoly1305-IETF (96 bit nonce) as
+ * separate arrays (but wrapped inside [AeadEncryptedDataAndTag])
+ *
+ * @param message message to encrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a **unique** nonce
+ * @param key secret key
+ * @return encrypted data and tag wrapped inside [AeadEncryptedDataAndTag] data class instance
+ */
fun chaCha20Poly1305IetfEncryptDetached(
message: UByteArray,
associatedData: UByteArray,
@@ -81,6 +180,18 @@ expect object AuthenticatedEncryptionWithAssociatedData {
key: UByteArray
): AeadEncryptedDataAndTag
+ /**
+ * Check if authentication data (tag) is correct, then decrypt the message and return decrypted data.
+ * Using xChaChaPoly1305 (96 bit nonce)
+ *
+ * @param ciphertext message to decrypt
+ * @param tag authenticatoin data (tag)
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a nonce used to encrypt the message
+ * @param key secret key
+ * @return decrypted data
+ * @throws AeadCorrupedOrTamperedDataException if authentication data (tag) cannot be verified
+ */
fun chaCha20Poly1305IetfDecryptDetached(
ciphertext: UByteArray,
tag: UByteArray,
@@ -90,28 +201,66 @@ expect object AuthenticatedEncryptionWithAssociatedData {
): UByteArray
// Original chacha20poly1305
-
+ /**
+ * Encrypt the message and return encrypted data and tag using ChaChaPoly1305 (64 bit nonce)
+ *
+ * @param message message to encrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a **unique** nonce
+ * @param key secret key
+ * @return encrypted data and tag (in that order)
+ */
fun chaCha20Poly1305Encrypt(
message: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray
-
+ /**
+ * Check if authentication data (tag) is correct, then decrypt the message and return decrypted data.
+ * Using ChaChaPoly1305 (64 bit nonce)
+ *
+ * @param ciphertextAndTag message to decrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a nonce used to encrypt the message
+ * @param key secret key
+ * @return decrypted data
+ * @throws AeadCorrupedOrTamperedDataException if authentication data (tag) cannot be verified
+ */
fun chaCha20Poly1305Decrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray
-
+ /**
+ * Encrypt the message and return encrypted data and tag using ChaChaPoly1305 (64 bit nonce) as
+ * separate arrays (but wrapped inside [AeadEncryptedDataAndTag])
+ *
+ * @param message message to encrypt
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a **unique** nonce
+ * @param key secret key
+ * @return encrypted data and tag wrapped inside [AeadEncryptedDataAndTag] data class instance
+ */
fun chaCha20Poly1305EncryptDetached(
message: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): AeadEncryptedDataAndTag
-
+ /**
+ * Check if authentication data (tag) is correct, then decrypt the message and return decrypted data.
+ * Using xChaChaPoly1305 (64 bit nonce)
+ *
+ * @param ciphertext message to decrypt
+ * @param tag authenticatoin data (tag)
+ * @param associatedData associated data the won't be encrypted, but will be authenticated
+ * @param nonce a nonce used to encrypt the message
+ * @param key secret key
+ * @return decrypted data
+ * @throws AeadCorrupedOrTamperedDataException if authentication data (tag) cannot be verified
+ */
fun chaCha20Poly1305DecryptDetached(
ciphertext: UByteArray,
tag: UByteArray,
@@ -120,9 +269,20 @@ expect object AuthenticatedEncryptionWithAssociatedData {
key: UByteArray
): UByteArray
-
- fun xChaCha20Poly1305IetfKeygen() : UByteArray
- fun chaCha20Poly1305IetfKeygen() : UByteArray
- fun chaCha20Poly1305Keygen() : UByteArray
+ /**
+ * Generate a random 32byte key for use with xChaCha20Poly1305
+ * @return secret key
+ */
+ fun xChaCha20Poly1305IetfKeygen(): UByteArray
+ /**
+ * Generate a random 32 byte key for use with ChaCha20Poly1305-IETF
+ * @return secret key
+ */
+ fun chaCha20Poly1305IetfKeygen(): UByteArray
+ /**
+ * Generate a random 32 byte key for use with ChaCha20Poly1305
+ * @return secret key
+ */
+ fun chaCha20Poly1305Keygen(): UByteArray
}
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.kt b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.kt
index 2b0d120..5ea7429 100644
--- a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.kt
@@ -19,18 +19,60 @@ val crypto_auth_hmacsha256_BYTES = 32
val crypto_auth_hmacsha512_KEYBYTES = 32
val crypto_auth_hmacsha512_BYTES = 64
+/**
+ * Authentication is a process of generating authentication data (tag) for a certain message. Its purpose is to assure
+ * that the data hasn't been corrupted or tampered with during the transport.
+ *
+ * We support 3 variants:
+ * - without suffix - HMAC-SHA512-256 (HMAC SHA512 with just the first 256 bits used)
+ * - *HmacSha256 - HMAC-SHA256
+ * - *HmacSha512 - HMAC-SHA512
+ *
+ * Each variant supports three operations:
+ * - keygen - generate appropriate key for MAC function
+ * - auth - generate the authentication data (tag/mac)
+ * - verify - verify that the authenticatoin data (tag/mac) is correct
+ */
expect object Auth {
-
+ /**
+ * Generate a secret key, meant to be used with auth function.
+ */
fun authKeygen() : UByteArray
+
+ /**
+ * Generate a HMAC-SHA512-256 authentication data - Message Authentication Code - tag
+ */
fun auth(message: UByteArray, key: UByteArray) : UByteArray
- fun authVerify(mac: UByteArray, message: UByteArray, key: UByteArray) : Boolean
+ /**
+ * Verify that given message, secret key and tag, a newly calculated tag matches the received HMAC-SHA512-256 tag.
+ */
+ fun authVerify(tag: UByteArray, message: UByteArray, key: UByteArray) : Boolean
+
+ /**
+ * Generate a secret key, meant to be used with auth function.
+ */
fun authHmacSha256Keygen() : UByteArray
+ /**
+ * Generate a HMAC-SHA256 authentication data - Message Authentication Code - tag
+ */
fun authHmacSha256(message: UByteArray, key: UByteArray) : UByteArray
- fun authHmacSha256Verify(mac: UByteArray, message: UByteArray, key: UByteArray) : Boolean
+ /**
+ * Verify that given message, secret key and tag, a newly calculated tag matches the received HMAC-SHA256 tag.
+ */
+ fun authHmacSha256Verify(tag: UByteArray, message: UByteArray, key: UByteArray) : Boolean
+ /**
+ * Generate a secret key, meant to be used with auth function.
+ */
fun authHmacSha512Keygen() : UByteArray
+ /**
+ * Generate a HMAC-SHA512 authentication data - Message Authentication Code - tag
+ */
fun authHmacSha512(message: UByteArray, key: UByteArray) : UByteArray
- fun authHmacSha512Verify(mac: UByteArray, message: UByteArray, key: UByteArray) : Boolean
+ /**
+ * Verify that given message, secret key and tag, a newly calculated tag matches the received HMAC-SHA512 tag.
+ */
+ fun authHmacSha512Verify(tag: UByteArray, message: UByteArray, key: UByteArray) : Boolean
}
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.md b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.md
new file mode 100644
index 0000000..dd7fa29
--- /dev/null
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/auth/Auth.md
@@ -0,0 +1,21 @@
+# Package com.ionspin.kotlin.crypto.auth
+
+## Authentication
+
+Authentication is a process of generating authentication data (tag) for a certain message. Its purpose is to assure
+that the data hasn't been corrupted or tampered with during the transport.
+
+In general, it works like this:
+
+Inputs:
+- Message to authenticate
+- Key to use for authentication
+
+Sending side algorithm:
+1. Apply MAC to message
+1. Send the message + authentication data (tag)
+
+Receiving side:
+1. Apply the MAC to the received message
+1. If the generated authenticated data (tag), and the received authentication data (received tag) match, proceed, otherwise sound the alarm and stop.
+1. Return the message to the user
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.kt b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.kt
index fdbc907..847fe84 100644
--- a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.kt
@@ -19,6 +19,9 @@ data class BoxEncryptedDataAndTag(val ciphertext: UByteArray, val tag: UByteArra
class BoxCorruptedOrTamperedDataException() : RuntimeException("MAC validation failed. Data is corrupted or tampered with.")
+/**
+ * Box API uses public-key (asymmetric) encryption to
+ */
expect object Box {
/**
* The crypto_box_keypair() function randomly generates a secret key and a corresponding public key.
@@ -87,4 +90,4 @@ expect object Box {
fun sealOpen(ciphertext: UByteArray, recipientsPublicKey: UByteArray, recipientsSecretKey: UByteArray) : UByteArray
-}
\ No newline at end of file
+}
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.md b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.md
new file mode 100644
index 0000000..035c9d3
--- /dev/null
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/box/Box.md
@@ -0,0 +1,31 @@
+# Package com.ionspin.kotlin.crypto.box
+
+## Box API - Asymmetric/Public-key authenticated encryption
+
+Public key encryption is a system that relies on a pair of keys to establish secure communication.
+
+A simplified overview of communication between Bob and Alice using public-key encryption:
+#### Key exchange
+1. Alice creates 2 keys, one public, one private (public key is actually calculated from the private key)
+1. Bob creates 2 keys, one public, one private
+1. Alice sends her **public** key to Bob
+1. Bob does the same and sends his **public** key to Alice
+
+#### Encryption
+
+Alice wants to establish a secure communication channel with Bob, they already exchanged public keys in previous steps.
+
+1. Alice uses Bobs **private** key to encrypt a *secret value* (Usually just a key for symmetric encryption)
+1. Alice sends encrypted data to Bob
+1. Bob is the only one who has the matching private key, and can decrypt the data
+1. Bob and Alice now posses the same *secret value* and can start communicating (i.e. by using XChaCha20Poly1305
+symmetric encryption and using the *secret value* as the symmetric key)
+
+Bob would do the same if he wanted to initiate the secure communication.
+
+This set of functions also contains another use case called `sealed boxes` in libsodium.
+Sealed box is designed to anonymously send a message to a recipient. Libsodium documentation explains it as follows:
+> A message is encrypted using an ephemeral key pair, whose secret part is destroyed right after the encryption process.
+ Without knowing the secret key used for a given message, the sender cannot decrypt its own message later. And without additional data, a message cannot be correlated with the identity of its sender.
+
+
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/generichash/GenericHash.kt b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/generichash/GenericHash.kt
index c778647..4c5a829 100644
--- a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/generichash/GenericHash.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/generichash/GenericHash.kt
@@ -21,14 +21,34 @@ data class GenericHashState(val hashLength: Int, val internalState: GenericHashS
expect object GenericHash {
+ /**
+ * Request computing a hash of message, with a specific hash length and optional key. The specific hash length can be
+ * between [crypto_generichash_blake2b_BYTES_MIN] and [crypto_generichash_blake2b_BYTES_MAX]. If the key is provided
+ * it needs the hash will be different for each different key.
+ */
+ fun genericHash(message : UByteArray, requestedHashLength: Int = crypto_generichash_BYTES, key : UByteArray? = null) : UByteArray
- fun genericHash(message : UByteArray, requestedHashLength: Int, key : UByteArray? = null) : UByteArray
+ /**
+ * Prepare a Generic Hash State object that will be used to compute hash of data with arbitrary length. Secific hash length
+ * can be requested
+ */
+ fun genericHashInit(requestedHashLength: Int = crypto_generichash_BYTES, key : UByteArray? = null) : GenericHashState
- fun genericHashInit(requestedHashLength: Int, key : UByteArray? = null) : GenericHashState
+ /**
+ * Feed another chunk of message to the updateable hash object
+ */
fun genericHashUpdate(state: GenericHashState, messagePart : UByteArray)
+
+ /**
+ * Feed the last chunk of message to the updateable hash object. This returns the actual hash.
+ */
fun genericHashFinal(state : GenericHashState) : UByteArray
+ /**
+ * Generate a key of length [crypto_generichash_blake2b_KEYBYTES] that can be used with the generic hash funciton
+ */
fun genericHashKeygen() : UByteArray
+
// ---- Not present in LazySodium nor libsodium.js
// fun blake2b(message : UByteArray, requestedHashLength: Int, key : UByteArray? = null) : UByteArray
//
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/generichash/GenericHash.md b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/generichash/GenericHash.md
new file mode 100644
index 0000000..091c997
--- /dev/null
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/generichash/GenericHash.md
@@ -0,0 +1,23 @@
+# Package com.ionspin.kotlin.crypto.generichash
+
+## Generic hash
+
+Generic hash package provides a easy to use hashing API that computes fixed-length fingerprint for an arbitrary long message.
+
+In this case hashing is a process of mapping a set of input bytes to a fixed length (32 bytes) output. Loosely speaking
+hash function should be practically irreversible and resistant to collisions (a case where two different inputs result in a same output)
+
+Some examples of hash function usage:
+- Verifying data integrity, i.e. downloading a file and it's hash and then recalculating the hash of the downloaded
+file to verify that it hasn't changed
+- Creating unique identifiers to index long data
+- Password verification, i.e. server stores just the hash of the users password and then when user wants to log in, they send
+the password, which server then hashes and compares to the stored hash. This way in case of breach of server security cleartext
+passwords are not revealed. With that said **DONT USE GENERIC HASH FOR PASSWORD HASHING**. Use PasswordHash funcitons.
+
+Underneath this set of functions uses BLAKE2b secure hash function, Here is what Libsodium documentation says about it
+>The crypto_generichash_* function set is implemented using BLAKE2b, a simple, standardized (RFC 7693) secure hash
+>function that is as strong as SHA-3 but faster than SHA-1 and MD5.
+>Unlike MD5, SHA-1 and SHA-256, this function is safe against hash length extension attacks.
+>BLAKE2b is not suitable for hashing passwords. For this purpose, use the crypto_pwhash API documented
+>in the Password Hashing section.
diff --git a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/util/Util.kt b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/util/Util.kt
index b3034e7..97cb9f7 100644
--- a/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/util/Util.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/commonMain/kotlin/com.ionspin.kotlin.crypto/util/Util.kt
@@ -9,10 +9,14 @@ fun String.hexStringToUByteArray() : UByteArray {
return this.chunked(2).map { it.toUByte(16) }.toUByteArray()
}
-fun String.encodeToUByteArray() : UByteArray{
+ fun String.encodeToUByteArray() : UByteArray{
return encodeToByteArray().asUByteArray()
}
+ fun UByteArray.decodeFromUByteArray() : String {
+ return asByteArray().decodeToString()
+}
+
fun UByteArray.toHexString() : String {
return this.joinToString(separator = "") {
if (it <= 0x0FU) {
diff --git a/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt b/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
index 846ccb7..c74369b 100644
--- a/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
@@ -26,7 +26,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun xChaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
@@ -34,7 +34,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
try {
return getSodium().crypto_aead_xchacha20poly1305_ietf_decrypt(
null,
- ciphertext.toUInt8Array(),
+ ciphertextAndTag.toUInt8Array(),
associatedData.toUInt8Array(),
nonce.toUInt8Array(),
key.toUInt8Array()
@@ -100,7 +100,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun chaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
@@ -108,7 +108,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
try {
return getSodium().crypto_aead_chacha20poly1305_ietf_decrypt(
null,
- ciphertext.toUInt8Array(),
+ ciphertextAndTag.toUInt8Array(),
associatedData.toUInt8Array(),
nonce.toUInt8Array(),
key.toUInt8Array()
@@ -174,7 +174,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun chaCha20Poly1305Decrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
@@ -182,7 +182,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
try {
return getSodium().crypto_aead_chacha20poly1305_decrypt(
null,
- ciphertext.toUInt8Array(),
+ ciphertextAndTag.toUInt8Array(),
associatedData.toUInt8Array(),
nonce.toUInt8Array(),
key.toUInt8Array()
diff --git a/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt b/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
index 50cf35a..338cc3d 100644
--- a/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/jsMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
@@ -3,7 +3,6 @@ package com.ionspin.kotlin.crypto.auth
import com.ionspin.kotlin.crypto.getSodium
import ext.libsodium.com.ionspin.kotlin.crypto.toUByteArray
import ext.libsodium.com.ionspin.kotlin.crypto.toUInt8Array
-import org.khronos.webgl.Uint8Array
actual object Auth {
actual fun authKeygen(): UByteArray {
@@ -18,9 +17,9 @@ actual object Auth {
}
- actual fun authVerify(mac: UByteArray, message: UByteArray, key: UByteArray): Boolean {
+ actual fun authVerify(tag: UByteArray, message: UByteArray, key: UByteArray): Boolean {
return getSodium().crypto_auth_verify(
- mac.toUInt8Array(),
+ tag.toUInt8Array(),
message.toUInt8Array(),
key.toUInt8Array()
)
@@ -38,12 +37,12 @@ actual object Auth {
}
actual fun authHmacSha256Verify(
- mac: UByteArray,
+ tag: UByteArray,
message: UByteArray,
key: UByteArray
): Boolean {
return getSodium().crypto_auth_hmacsha256_verify(
- mac.toUInt8Array(),
+ tag.toUInt8Array(),
message.toUInt8Array(),
key.toUInt8Array()
)
@@ -61,12 +60,12 @@ actual object Auth {
}
actual fun authHmacSha512Verify(
- mac: UByteArray,
+ tag: UByteArray,
message: UByteArray,
key: UByteArray
): Boolean {
return getSodium().crypto_auth_hmacsha512_verify(
- mac.toUInt8Array(),
+ tag.toUInt8Array(),
message.toUInt8Array(),
key.toUInt8Array()
)
diff --git a/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt b/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
index 8fa92fd..523fb9a 100644
--- a/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
@@ -29,18 +29,18 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun xChaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray {
- val message = UByteArray(ciphertext.size - crypto_aead_xchacha20poly1305_ietf_ABYTES)
+ val message = UByteArray(ciphertextAndTag.size - crypto_aead_xchacha20poly1305_ietf_ABYTES)
val validationResult = sodium.crypto_aead_xchacha20poly1305_ietf_decrypt(
message.asByteArray(),
null,
null,
- ciphertext.asByteArray(),
- ciphertext.size.toLong(),
+ ciphertextAndTag.asByteArray(),
+ ciphertextAndTag.size.toLong(),
associatedData.asByteArray(),
associatedData.size.toLong(),
nonce.asByteArray(),
@@ -122,18 +122,18 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun chaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray {
- val message = UByteArray(ciphertext.size - crypto_aead_chacha20poly1305_ietf_ABYTES)
+ val message = UByteArray(ciphertextAndTag.size - crypto_aead_chacha20poly1305_ietf_ABYTES)
val validationResult = sodium.crypto_aead_chacha20poly1305_ietf_decrypt(
message.asByteArray(),
null,
null,
- ciphertext.asByteArray(),
- ciphertext.size.toLong(),
+ ciphertextAndTag.asByteArray(),
+ ciphertextAndTag.size.toLong(),
associatedData.asByteArray(),
associatedData.size.toLong(),
nonce.asByteArray(),
@@ -215,18 +215,18 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun chaCha20Poly1305Decrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray {
- val message = UByteArray(ciphertext.size - crypto_aead_chacha20poly1305_ABYTES)
+ val message = UByteArray(ciphertextAndTag.size - crypto_aead_chacha20poly1305_ABYTES)
val validationResult = sodium.crypto_aead_chacha20poly1305_decrypt(
message.asByteArray(),
null,
null,
- ciphertext.asByteArray(),
- ciphertext.size.toLong(),
+ ciphertextAndTag.asByteArray(),
+ ciphertextAndTag.size.toLong(),
associatedData.asByteArray(),
associatedData.size.toLong(),
nonce.asByteArray(),
diff --git a/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt b/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
index afaec45..e6b6207 100644
--- a/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
@@ -20,9 +20,9 @@ actual object Auth {
return mac
}
- actual fun authVerify(mac: UByteArray, message: UByteArray, key: UByteArray): Boolean {
+ actual fun authVerify(tag: UByteArray, message: UByteArray, key: UByteArray): Boolean {
return sodium.crypto_auth_verify(
- mac.asByteArray(),
+ tag.asByteArray(),
message.asByteArray(),
message.size.toLong(),
key.asByteArray()
@@ -47,12 +47,12 @@ actual object Auth {
}
actual fun authHmacSha256Verify(
- mac: UByteArray,
+ tag: UByteArray,
message: UByteArray,
key: UByteArray
): Boolean {
return sodium.crypto_auth_hmacsha256_verify(
- mac.asByteArray(),
+ tag.asByteArray(),
message.asByteArray(),
message.size.toLong(),
key.asByteArray()
@@ -77,12 +77,12 @@ actual object Auth {
}
actual fun authHmacSha512Verify(
- mac: UByteArray,
+ tag: UByteArray,
message: UByteArray,
key: UByteArray
): Boolean {
return sodium.crypto_auth_hmacsha512_verify(
- mac.asByteArray(),
+ tag.asByteArray(),
message.asByteArray(),
message.size.toLong(),
key.asByteArray()
diff --git a/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt b/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
index 6d0531d..a73788b 100644
--- a/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/aead/AuthenticatedEncryptionWithAssociatedData.kt
@@ -62,17 +62,17 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun xChaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray {
- val ciphertextPinned = ciphertext.pin()
+ val ciphertextPinned = ciphertextAndTag.pin()
val associatedDataPinned = associatedData.pin()
val noncePinned = nonce.pin()
val keyPinned = key.pin()
- val message = UByteArray(ciphertext.size - crypto_aead_xchacha20poly1305_ietf_ABYTES)
+ val message = UByteArray(ciphertextAndTag.size - crypto_aead_xchacha20poly1305_ietf_ABYTES)
val messagePinned = message.pin()
val validationResult = crypto_aead_xchacha20poly1305_ietf_decrypt(
@@ -80,7 +80,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
null,
null,
ciphertextPinned.toPtr(),
- ciphertext.size.convert(),
+ ciphertextAndTag.size.convert(),
associatedDataPinned.toPtr(),
associatedData.size.convert(),
noncePinned.toPtr(),
@@ -223,17 +223,17 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun chaCha20Poly1305IetfDecrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray {
- val ciphertextPinned = ciphertext.pin()
+ val ciphertextPinned = ciphertextAndTag.pin()
val associatedDataPinned = associatedData.pin()
val noncePinned = nonce.pin()
val keyPinned = key.pin()
- val message = UByteArray(ciphertext.size - crypto_aead_chacha20poly1305_ietf_ABYTES)
+ val message = UByteArray(ciphertextAndTag.size - crypto_aead_chacha20poly1305_ietf_ABYTES)
val messagePinned = message.pin()
val validationResult = crypto_aead_chacha20poly1305_ietf_decrypt(
@@ -241,7 +241,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
null,
null,
ciphertextPinned.toPtr(),
- ciphertext.size.convert(),
+ ciphertextAndTag.size.convert(),
associatedDataPinned.toPtr(),
associatedData.size.convert(),
noncePinned.toPtr(),
@@ -384,17 +384,17 @@ actual object AuthenticatedEncryptionWithAssociatedData {
}
actual fun chaCha20Poly1305Decrypt(
- ciphertext: UByteArray,
+ ciphertextAndTag: UByteArray,
associatedData: UByteArray,
nonce: UByteArray,
key: UByteArray
): UByteArray {
- val ciphertextPinned = ciphertext.pin()
+ val ciphertextPinned = ciphertextAndTag.pin()
val associatedDataPinned = associatedData.pin()
val noncePinned = nonce.pin()
val keyPinned = key.pin()
- val message = UByteArray(ciphertext.size - crypto_aead_chacha20poly1305_ABYTES)
+ val message = UByteArray(ciphertextAndTag.size - crypto_aead_chacha20poly1305_ABYTES)
val messagePinned = message.pin()
val validationResult = crypto_aead_chacha20poly1305_decrypt(
@@ -402,7 +402,7 @@ actual object AuthenticatedEncryptionWithAssociatedData {
null,
null,
ciphertextPinned.toPtr(),
- ciphertext.size.convert(),
+ ciphertextAndTag.size.convert(),
associatedDataPinned.toPtr(),
associatedData.size.convert(),
noncePinned.toPtr(),
diff --git a/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt b/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
index 1964240..ecfa2dc 100644
--- a/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
+++ b/multiplatform-crypto-libsodium-bindings/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/auth/Auth.kt
@@ -43,8 +43,8 @@ actual object Auth {
return mac
}
- actual fun authVerify(mac: UByteArray, message: UByteArray, key: UByteArray): Boolean {
- val macPinned = mac.pin()
+ actual fun authVerify(tag: UByteArray, message: UByteArray, key: UByteArray): Boolean {
+ val macPinned = tag.pin()
val messagePinned = message.pin()
val keyPinned = key.pin()
val verify = crypto_auth_verify(
@@ -90,11 +90,11 @@ actual object Auth {
}
actual fun authHmacSha256Verify(
- mac: UByteArray,
+ tag: UByteArray,
message: UByteArray,
key: UByteArray
): Boolean {
- val macPinned = mac.pin()
+ val macPinned = tag.pin()
val messagePinned = message.pin()
val keyPinned = key.pin()
@@ -141,11 +141,11 @@ actual object Auth {
}
actual fun authHmacSha512Verify(
- mac: UByteArray,
+ tag: UByteArray,
message: UByteArray,
key: UByteArray
): Boolean {
- val macPinned = mac.pin()
+ val macPinned = tag.pin()
val messagePinned = message.pin()
val keyPinned = key.pin()
diff --git a/multiplatform-crypto/build.gradle.kts b/multiplatform-crypto/build.gradle.kts
deleted file mode 100644
index d458d71..0000000
--- a/multiplatform-crypto/build.gradle.kts
+++ /dev/null
@@ -1,521 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *
- */
-
-@file:Suppress("UnstableApiUsage")
-import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest
-import org.jetbrains.kotlin.gradle.targets.js.testing.KotlinJsTest
-
-plugins {
- kotlin(PluginsDeps.multiplatform)
- id(PluginsDeps.mavenPublish)
- id(PluginsDeps.signing)
- id(PluginsDeps.node) version Versions.nodePlugin
- id(PluginsDeps.dokka)
-}
-
-val sonatypeStaging = "https://oss.sonatype.org/service/local/staging/deploy/maven2/"
-val sonatypeSnapshots = "https://oss.sonatype.org/content/repositories/snapshots/"
-
-val sonatypePassword: String? by project
-
-val sonatypeUsername: String? by project
-
-val sonatypePasswordEnv: String? = System.getenv()["SONATYPE_PASSWORD"]
-val sonatypeUsernameEnv: String? = System.getenv()["SONATYPE_USERNAME"]
-
-repositories {
- mavenCentral()
- jcenter()
-
-}
-group = ReleaseInfo.group
-version = ReleaseInfo.version
-
-val ideaActive = System.getProperty("idea.active") == "true"
-
-kotlin {
- val hostOsName = getHostOsName()
- val bla =1
- runningOnLinuxx86_64 {
- jvm()
- js {
-
- browser {
-
- testTask {
-// isRunningInTravis {
- enabled = false //Until I sort out testing on travis, and figure out how to increase karma timeout
-// }
- useKarma {
- useChrome()
-
- }
- }
- }
- nodejs {
- testTask {
- useMocha() {
- timeout = "10s"
- }
- }
- }
-
- }
- linuxX64("linux") {
- binaries {
- staticLib {
- optimized = true
- }
- }
- }
-
- linuxArm64() {
- binaries {
- staticLib {
- }
- }
- }
-
- linuxArm32Hfp() {
- binaries {
- staticLib {
- }
- }
- }
-
-
-
- }
-
- runningOnMacos {
- iosX64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
- iosArm64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- iosArm32() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
- macosX64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
- tvosX64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- tvosArm64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- watchosArm64() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- watchosArm32() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
-
- watchosX86() {
- binaries {
- framework {
- optimized = true
- }
- }
- }
- }
- runningOnWindows {
-
- mingwX64() {
- binaries {
- staticLib {
- optimized = true
- }
- }
- }
- }
-// No coroutines support for mingwX86
-// mingwX86() {
-// binaries {
-// staticLib {
-//
-// }
-// }
-// }
-
-
- println(targets.names)
-
- sourceSets {
- val commonMain by getting {
- dependencies {
- implementation(kotlin(Deps.Common.stdLib))
- implementation(kotlin(Deps.Common.test))
- implementation(Deps.Common.kotlinBigNum)
- implementation(project(Deps.Common.apiProject))
- }
- }
- val commonTest by getting {
- dependencies {
- implementation(kotlin(Deps.Common.test))
- implementation(kotlin(Deps.Common.testAnnotation))
- }
- }
-
-
- val nativeMain by creating {
- dependsOn(commonMain)
- dependencies {
- }
- isRunningInIdea {
- kotlin.setSrcDirs(emptySet())
- }
- }
-
-
- val nativeTest by creating {
- dependsOn(commonTest)
- dependencies {
- }
- }
-
- targets.withType {
- compilations.getByName("main") {
- println("Setting native sourceset dependancy for $name")
- if ((this@withType.name.contains("ios") ||
- this@withType.name.contains("mingw")).not()
- ) {
- println("Setting native sourceset dependancy for $this@withType.name")
- defaultSourceSet.dependsOn(nativeMain)
- }
- }
- compilations.getByName("test") {
- println("Setting native sourceset dependancy for $name")
- if ((this@withType.name.contains("ios") ||
- this@withType.name.contains("mingw")).not()
- ) {
- println("Setting native sourceset dependancy for $this@withType.name")
- defaultSourceSet.dependsOn(nativeTest)
- }
- }
- }
-
-
-
- runningOnLinuxx86_64 {
- val jvmMain by getting {
- dependencies {
- implementation(kotlin(Deps.Jvm.stdLib))
- implementation(kotlin(Deps.Jvm.test))
- implementation(kotlin(Deps.Jvm.testJUnit))
- }
- }
- val jvmTest by getting {
- dependencies {
- implementation(kotlin(Deps.Jvm.test))
- implementation(kotlin(Deps.Jvm.testJUnit))
- implementation(kotlin(Deps.Jvm.reflection))
- }
- }
- val jsMain by getting {
- dependencies {
- implementation(kotlin(Deps.Js.stdLib))
- }
- }
- val jsTest by getting {
- dependencies {
- implementation(kotlin(Deps.Js.test))
- }
- }
- val linuxMain by getting {
- dependsOn(nativeMain)
- //Force idea to consider native sourceset
- if (ideaActive) {
- kotlin.srcDir("src/nativeMain/kotlin")
- }
- }
- val linuxTest by getting {
- dependsOn(nativeTest)
-// Force idea to consider native sourceset
- if (ideaActive) {
- kotlin.srcDir("src/nativeTest/kotlin")
- }
- }
-
- val linuxArm64Main by getting {
- dependsOn(nativeMain)
- }
-
- val linuxArm64Test by getting {
- dependsOn(nativeTest)
- }
-
- val linuxArm32HfpMain by getting {
- dependsOn(nativeMain)
- }
-
- val linuxArm32HfpTest by getting {
- dependsOn(nativeTest)
- }
-
- }
-
-
- runningOnMacos{
-
- val iosX64Main by getting {
- dependsOn(nativeMain)
- }
- val iosX64Test by getting {
- dependsOn(nativeTest)
- }
-
- val iosArm64Main by getting {
- dependsOn(nativeMain)
- }
- val iosArm64Test by getting {
- dependsOn(nativeTest)
- }
-
- val iosArm32Main by getting {
- dependsOn(nativeMain)
- }
- val iosArm32Test by getting {
- dependsOn(nativeTest)
- }
-
- val macosX64Main by getting {
- dependsOn(commonMain)
- if (ideaActive) {
- kotlin.srcDir("src/nativeMain/kotlin")
- }
- }
- val macosX64Test by getting {
- dependsOn(commonTest)
- if (ideaActive) {
- kotlin.srcDir("src/nativeTest/kotlin")
- }
- }
- }
-
-// Coroutines don't support mingwx86 yet
-// val mingwX86Main by getting {
-// dependsOn(commonMain)
-// dependencies {
-// }
-// }
-
-// val mingwX86Test by getting {
-// dependsOn(commonTest)
-// }
-//
- runningOnWindows {
- val mingwX64Main by getting {
- dependsOn(commonMain)
- dependencies {
- }
- }
-
- val mingwX64Test by getting {
- dependsOn(commonTest)
- }
- }
-
-
- all {
- languageSettings.enableLanguageFeature("InlineClasses")
- languageSettings.useExperimentalAnnotation("kotlin.ExperimentalUnsignedTypes")
- languageSettings.useExperimentalAnnotation("kotlin.ExperimentalStdlibApi")
- }
- }
-
-
-}
-
-
-
-task("copyPackageJson") {
- dependsOn("compileKotlinJs")
- println("Copying package.json from $projectDir/core/src/jsMain/npm")
- from("$projectDir/src/jsMain/npm")
- println("Node modules dir ${node.nodeModulesDir}")
- into("${node.nodeModulesDir}")
-}
-
-tasks {
-
-
- create("javadocJar") {
- dependsOn(dokkaJavadoc)
- archiveClassifier.set("javadoc")
- from(dokkaJavadoc.get().outputDirectory)
- }
-
- dokkaJavadoc {
- println("Dokka !")
- dokkaSourceSets {
- create("commonMain") {
- displayName = "common"
- platform = "common"
- }
- }
-
-
-
- }
- if (getHostOsName() == "linux" && getHostArchitecture() == "x86-64") {
-
- val jvmTest by getting(Test::class) {
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
- }
- }
-
- val linuxTest by getting(KotlinNativeTest::class) {
-
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
-// showStandardStreams = true
- }
- }
-
- val jsNodeTest by getting(KotlinJsTest::class) {
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
- showStandardStreams = true
- }
- }
-
-// val legacyjsNodeTest by getting(KotlinJsTest::class) {
-//
-// testLogging {
-// events("PASSED", "FAILED", "SKIPPED")
-// showStandardStreams = true
-// }
-// }
-
-// val jsIrBrowserTest by getting(KotlinJsTest::class) {
-// testLogging {
-// events("PASSED", "FAILED", "SKIPPED")
-// showStandardStreams = true
-// }
-// }
- }
-
- if (getHostOsName() == "windows") {
- val mingwX64Test by getting(KotlinNativeTest::class) {
-
- testLogging {
- events("PASSED", "FAILED", "SKIPPED")
- showStandardStreams = true
- }
- }
- }
-
-}
-
-
-
-signing {
- isRequired = false
- sign(publishing.publications)
-}
-
-publishing {
- publications.withType(MavenPublication::class) {
- artifact(tasks["javadocJar"])
- pom {
- name.set("Kotlin Multiplatform Crypto")
- description.set("Kotlin Multiplatform Crypto library")
- url.set("https://github.com/ionspin/kotlin-multiplatform-crypto")
- licenses {
- license {
- name.set("The Apache License, Version 2.0")
- url.set("http://www.apache.org/licenses/LICENSE-2.0.txt")
- }
- }
- developers {
- developer {
- id.set("ionspin")
- name.set("Ugljesa Jovanovic")
- email.set("opensource@ionspin.com")
- }
- }
- scm {
- url.set("https://github.com/ionspin/kotlin-multiplatform-crypto")
- connection.set("scm:git:git://git@github.com:ionspin/kotlin-multiplatform-crypto.git")
- developerConnection.set("scm:git:ssh://git@github.com:ionspin/kotlin-multiplatform-crypto.git")
-
- }
-
- }
- }
- repositories {
- maven {
-
- url = uri(sonatypeStaging)
- credentials {
- username = sonatypeUsername ?: sonatypeUsernameEnv ?: ""
- password = sonatypePassword ?: sonatypePasswordEnv ?: ""
- }
- }
-
- maven {
- name = "snapshot"
- url = uri(sonatypeSnapshots)
- credentials {
- username = sonatypeUsername ?: sonatypeUsernameEnv ?: ""
- password = sonatypePassword ?: sonatypePasswordEnv ?: ""
- }
- }
- }
-}
-
-
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Config.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Config.kt
deleted file mode 100644
index eb058b8..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Config.kt
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 20-Jul-2019
- */
-object Config {
- const val DEBUG = false
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Crypto.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Crypto.kt
deleted file mode 100644
index d13f8ca..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/Crypto.kt
+++ /dev/null
@@ -1,155 +0,0 @@
-package com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.authenticated.*
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bMultipart
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bPure
-import com.ionspin.kotlin.crypto.hash.sha.Sha256Pure
-import com.ionspin.kotlin.crypto.hash.sha.Sha512Pure
-import com.ionspin.kotlin.crypto.keyderivation.ArgonResult
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Pure
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 24-May-2020
- */
-object CryptoInitializerPure : CryptoInitializer {
- override suspend fun initialize() {
- //Nothing to do atm.
- }
-
- fun initializeWithCallback(done: () -> Unit) {
- done()
- }
-
- override fun isInitialized(): Boolean {
- return true
- }
-}
-
-object CryptoPrimitives : PrimitivesApi {
- private fun checkInitialization() {
- CryptoInitializerPure.isInitialized()
- }
-
- override fun hashBlake2bMultipart(key: UByteArray?, hashLength: Int): Blake2bMultipart {
- checkInitialization()
- return Blake2bPure(key, hashLength)
- }
-
- override fun hashBlake2b(message: UByteArray, key: UByteArray, hashLength: Int): UByteArray {
- checkInitialization()
- return Blake2bPure.digest(message, key, hashLength)
- }
-
- override fun hashSha256Multipart(): com.ionspin.kotlin.crypto.hash.sha.Sha256 {
- checkInitialization()
- return Sha256Pure()
- }
-
- override fun hashSha256(message: UByteArray): UByteArray {
- checkInitialization()
- return Sha256Pure.digest(inputMessage = message)
- }
-
- override fun hashSha512Multipart(): com.ionspin.kotlin.crypto.hash.sha.Sha512Multipart {
- checkInitialization()
- return Sha512Pure()
- }
-
- override fun hashSha512(message: UByteArray): UByteArray {
- checkInitialization()
- return Sha512Pure.digest(inputMessage = message)
- }
-
- override fun deriveKey(
- password: String,
- salt: String?,
- key: String,
- associatedData: String,
- parallelism: Int,
- tagLength: Int,
- memory: Int,
- numberOfIterations: Int
- ): ArgonResult {
- return Argon2Pure.derive(
- password,
- salt,
- key,
- associatedData,
- parallelism,
- tagLength,
- memory,
- numberOfIterations
- )
- }
-}
-
-fun SymmetricKey.Companion.randomKey() : SymmetricKey {
- return SymmetricKey(SRNG.getRandomBytes(32))
-}
-
-object Crypto {
-
- object Hash : HashApi {
- override fun hash(data: UByteArray, key : UByteArray) : HashedData {
- return HashedData(Blake2bPure.digest(data, key))
- }
-
- override fun multipartHash(key: UByteArray?) : com.ionspin.kotlin.crypto.hash.MultipartHash {
- return Blake2bPure(key)
- }
- }
-
- object Encryption : EncryptionApi {
- override fun encrypt(key: SymmetricKey, data : Encryptable<*>, associatedData : UByteArray) : EncryptedData {
- if (key.value.size != 32) {
- throw RuntimeException("Invalid key size! Required 32, supplied ${key.value.size}")
- }
- val nonce = SRNG.getRandomBytes(24)
- return EncryptedData(XChaCha20Poly1305Pure.encrypt(key.value, nonce, data.toEncryptableForm(), associatedData), nonce)
-
- }
-
- override fun > decrypt(key: SymmetricKey, encryptedData : EncryptedData, associatedData: UByteArray, byteArrayDeserializer : (UByteArray) -> T) : T {
- return byteArrayDeserializer(XChaCha20Poly1305Pure.decrypt(key.value, encryptedData.nonce, encryptedData.ciphertext, associatedData))
-
- }
-
- override fun createMultipartEncryptor(key: SymmetricKey) : MultipartAuthenticatedEncryption {
- return MultipartAuthenticatedEncryptor(key)
- }
-
- override fun createMultipartDecryptor(key: SymmetricKey, header: MultipartEncryptionHeader) : MultipartAuthenticatedDecryption {
- val decryptor = XChaCha20Poly1305Pure(key.value, header.nonce)
- return MultipartAuthenticatedDecryptor(decryptor)
- }
- }
-}
-
-class MultipartAuthenticatedEncryptor internal constructor(val key : SymmetricKey) : MultipartAuthenticatedEncryption {
- val header = MultipartEncryptionHeader(SRNG.getRandomBytes(24))
- val primitive = XChaCha20Poly1305Pure(key.value, header.nonce)
- override fun encryptPartialData(data: UByteArray, associatedData: UByteArray): EncryptedDataPart {
- return EncryptedDataPart(primitive.streamEncrypt(data, associatedData, 0U))
- }
-
- override fun startEncryption(): MultipartEncryptionHeader {
- return header.copy()
- }
-
- override fun cleanup() {
- primitive.cleanup()
- }
-}
-
-class MultipartAuthenticatedDecryptor internal constructor(val decryptor: XChaCha20Poly1305Pure) : MultipartAuthenticatedDecryption {
- override fun decryptPartialData(data: EncryptedDataPart, associatedData: UByteArray): DecryptedDataPart {
- return DecryptedDataPart(decryptor.streamDecrypt(data.data, associatedData, 0U))
- }
-
- override fun cleanup() {
- decryptor.cleanup()
- }
-
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/NativeInlineClassEmitter.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/NativeInlineClassEmitter.kt
deleted file mode 100644
index 8fec2b1..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/NativeInlineClassEmitter.kt
+++ /dev/null
@@ -1,12 +0,0 @@
-package _multiplatform_crypto
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 24-May-2020
- */
-//Workaround for https://youtrack.jetbrains.com/issue/KT-36878
-val byteArray = byteArrayOf(0)
-val byte = 0.toByte()
-val longArray = longArrayOf(0)
-val long = 0L
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index 80e6f05..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-expect object SRNG {
- fun getRandomBytes(amount : Int) : UByteArray
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/ChaCha20Poly1305Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/ChaCha20Poly1305Pure.kt
deleted file mode 100644
index 1c35fd9..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/ChaCha20Poly1305Pure.kt
+++ /dev/null
@@ -1,50 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.ionspin.kotlin.crypto.mac.Poly1305
-import com.ionspin.kotlin.crypto.symmetric.ChaCha20Pure
-import com.ionspin.kotlin.crypto.util.fromLittleEndianArrayToUIntWithPosition
-import com.ionspin.kotlin.crypto.util.toLittleEndianUByteArray
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jun-2020
- */
-internal class ChaCha20Poly1305Pure {
- companion object {
-
- fun encrypt(key: UByteArray, nonce: UByteArray, message: UByteArray, associatedData: UByteArray) : UByteArray {
- val state = UIntArray(16) {
- when (it) {
- 0 -> ChaCha20Pure.sigma0_32
- 1 -> ChaCha20Pure.sigma1_32
- 2 -> ChaCha20Pure.sigma2_32
- 3 -> ChaCha20Pure.sigma3_32
- 4 -> key.fromLittleEndianArrayToUIntWithPosition(0)
- 5 -> key.fromLittleEndianArrayToUIntWithPosition(4)
- 6 -> key.fromLittleEndianArrayToUIntWithPosition(8)
- 7 -> key.fromLittleEndianArrayToUIntWithPosition(12)
- 8 -> key.fromLittleEndianArrayToUIntWithPosition(16)
- 9 -> key.fromLittleEndianArrayToUIntWithPosition(20)
- 10 -> key.fromLittleEndianArrayToUIntWithPosition(24)
- 11 -> key.fromLittleEndianArrayToUIntWithPosition(28)
- 12 -> 0U
- 13 -> nonce.fromLittleEndianArrayToUIntWithPosition(0)
- 14 -> nonce.fromLittleEndianArrayToUIntWithPosition(4)
- 15 -> nonce.fromLittleEndianArrayToUIntWithPosition(8)
- else -> 0U
- }
- }
- val oneTimeKey = ChaCha20Pure.hash(state).sliceArray(0 until 32)
- val cipherText = ChaCha20Pure.xorWithKeystream(key, nonce, message, 1U)
- val associatedDataPad = UByteArray(16 - associatedData.size % 16) { 0U }
- val cipherTextPad = UByteArray(16 - cipherText.size % 16) { 0U }
- val macData = associatedData + associatedDataPad +
- cipherText + cipherTextPad +
- associatedData.size.toULong().toLittleEndianUByteArray() +
- cipherText.size.toULong().toLittleEndianUByteArray()
- val tag = Poly1305.poly1305Authenticate(oneTimeKey, macData)
- return cipherText + tag
- }
- }
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Pure.kt
deleted file mode 100644
index 34b8c01..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Pure.kt
+++ /dev/null
@@ -1,203 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.ionspin.kotlin.crypto.AuthenticatedEncryption
-import com.ionspin.kotlin.crypto.InvalidTagException
-import com.ionspin.kotlin.crypto.mac.Poly1305
-import com.ionspin.kotlin.crypto.symmetric.ChaCha20Pure
-import com.ionspin.kotlin.crypto.symmetric.XChaCha20Pure
-import com.ionspin.kotlin.crypto.util.*
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jun-2020
- */
-class XChaCha20Poly1305Pure(val key: UByteArray, val nonce: UByteArray) {
- companion object : AuthenticatedEncryption {
-
- override fun encrypt(key: UByteArray, nonce: UByteArray, message: UByteArray, associatedData: UByteArray) : UByteArray {
- val subKey = XChaCha20Pure.hChacha(key, nonce)
- val authKey =
- ChaCha20Pure.xorWithKeystream(
- subKey.toLittleEndianUByteArray(),
- ubyteArrayOf(0U, 0U, 0U, 0U) + nonce.sliceArray(16 until 24),
- UByteArray(64) { 0U },
- 0U // If this is moved as a default parameter in encrypt, and not here (in 1.4-M2)
- // js compiler dies with: e: java.lang.NullPointerException
- // at org.jetbrains.kotlin.ir.backend.js.lower.ConstTransformer$visitConst$1$3.invoke(ConstLowering.kt:28)
- // at org.jetbrains.kotlin.ir.backend.js.lower.ConstTransformer.lowerConst(ConstLowering.kt:38)
- )
- val cipherText = XChaCha20Pure.xorWithKeystream(key, nonce, message, 1U)
- val associatedDataPad = UByteArray(16 - associatedData.size % 16) { 0U }
- val cipherTextPad = UByteArray(16 - cipherText.size % 16) { 0U }
- val macData = associatedData + associatedDataPad +
- cipherText + cipherTextPad +
- associatedData.size.toULong().toLittleEndianUByteArray() +
- cipherText.size.toULong().toLittleEndianUByteArray()
- val tag = Poly1305.poly1305Authenticate(authKey, macData)
- return cipherText + tag
- }
-
- override fun decrypt(key: UByteArray, nonce: UByteArray, cipherText: UByteArray, associatedData: UByteArray) : UByteArray {
- val subKey = XChaCha20Pure.hChacha(key, nonce)
- val authKey =
- ChaCha20Pure.xorWithKeystream(
- subKey.toLittleEndianUByteArray(),
- ubyteArrayOf(0U, 0U, 0U, 0U) + nonce.sliceArray(16 until 24),
- UByteArray(64) { 0U },
- 0U
- )
- //2. Get the tag
- val tag = cipherText.sliceArray(cipherText.size - 16 until cipherText.size)
- //3. Verify tag is valid
- val cipherTextWithoutTag = cipherText.sliceArray(0 until cipherText.size - 16)
- val associatedDataPad = UByteArray(16 - associatedData.size % 16) { 0U }
- val cipherTextPad = UByteArray(16 - cipherTextWithoutTag.size % 16) { 0U }
- val macData = associatedData + associatedDataPad +
- cipherTextWithoutTag + cipherTextPad +
- associatedData.size.toULong().toLittleEndianUByteArray() +
- cipherTextWithoutTag.size.toULong().toLittleEndianUByteArray()
- val calculatedTag = Poly1305.poly1305Authenticate(authKey, macData)
- if (!calculatedTag.contentEquals(tag)) {
- throw InvalidTagException()
- }
- //4. Decrypt data
- return XChaCha20Pure.xorWithKeystream(key, nonce, cipherTextWithoutTag, 1U)
- }
-
- }
-
-
- private val polyBuffer = UByteArray(16)
- private var polyBufferByteCounter = 0
-
- private var processedBytes = 0
-
- internal val calcKey : UByteArray = UByteArray(32)
- internal val calcNonce : UByteArray = UByteArray(12)
-
- init {
- val calc = XChaCha20Pure.hChacha(key, nonce).toLittleEndianUByteArray()
- calc.sliceArray(0 until 32).copyInto(calcKey)
- nonce.sliceArray(16 until 24).copyInto(calcNonce, 4)
- calcNonce[0] = 1U
- calcNonce[1] = 0U
- calcNonce[2] = 0U
- calcNonce[3] = 0U
- }
-
- fun streamEncrypt(data: UByteArray, associatedData: UByteArray, tag : UByte) : UByteArray {
- //get encryption state
- val block = UByteArray(64) { 0U }
- ChaCha20Pure.xorWithKeystream(calcKey, calcNonce, block, 0U).copyInto(block) // This is equivalent to the first 64 bytes of keystream
- val poly1305 = Poly1305(block)
- block.overwriteWithZeroes()
- if (associatedData.isNotEmpty()) {
- val associatedDataPadded = associatedData + UByteArray(16 - associatedData.size % 16) { 0U }
- processPolyBytes(poly1305, associatedDataPadded)
- }
- block[0] = tag
- ChaCha20Pure.xorWithKeystream(calcKey, calcNonce, block, 1U).copyInto(block) // This just xors block[0] with keystream
- processPolyBytes(poly1305, block) // but updates the mac with the full block!
- // In libsodium c code, it now sets the first byte to be a tag, we'll just save it for now
- val encryptedTag = block[0]
- //And then encrypt the rest of the message
- val ciphertext = ChaCha20Pure.xorWithKeystream(calcKey, calcNonce, data, 2U) // With appropriate counter
- // Next we update the poly1305 with ciphertext and padding, BUT the padding in libsodium is not correctly calculated, so it doesn't
- // pad correctly. https://github.com/jedisct1/libsodium/issues/976
- // We want to use libsodium in delegated flavour, so we will use the same incorrect padding here.
- // From security standpoint there are no obvious drawbacks, as padding was initially added to decrease implementation complexity.
- processPolyBytes(poly1305, ciphertext + UByteArray(((16U + data.size.toUInt() - block.size.toUInt()) % 16U).toInt()) { 0U } ) //TODO this is inefficient as it creates a new array and copies data
- // Last 16byte block containing actual additional data nad ciphertext sizes
- val finalMac = associatedData.size.toULong().toLittleEndianUByteArray() + (ciphertext.size + 64).toULong().toLittleEndianUByteArray()
- processPolyBytes(poly1305, finalMac)
- val mac = poly1305.finalizeMac(polyBuffer.sliceArray(0 until polyBufferByteCounter))
- calcNonce.xorWithPositionsAndInsertIntoArray(0, 12, mac, 0, calcNonce, 0)
- return ubyteArrayOf(encryptedTag) + ciphertext + mac
- }
-
- fun streamDecrypt(data: UByteArray, associatedData: UByteArray, tag: UByte) : UByteArray {
- val block = UByteArray(64) { 0U }
- ChaCha20Pure.xorWithKeystream(calcKey, calcNonce, block, 0U).copyInto(block) // This is equivalent to the first 64 bytes of keystream
- val poly1305 = Poly1305(block)
- block.overwriteWithZeroes()
- if (associatedData.isNotEmpty()) {
- val associatedDataPadded = associatedData + UByteArray(16 - associatedData.size % 16) { 0U }
- processPolyBytes(poly1305, associatedDataPadded)
- }
- block[0] = data[0]
- ChaCha20Pure.xorWithKeystream(calcKey, calcNonce, block, 1U).copyInto(block)// get the keystream xored with zeroes, but also decrypteg tag marker
- val tag = block[0] //get the decrypted tag
- block[0] = data[0] // this brings it back to state that is delivered to poly in encryption function
- processPolyBytes(poly1305, block)
- // Next we update the poly1305 with ciphertext and padding, BUT the padding in libsodium is not correctly calculated, so it doesn't
- // pad correctly. https://github.com/jedisct1/libsodium/issues/976
- // We want to use libsodium in delegated flavour, so we will use the same incorrect padding here.
- // From security standpoint there are no obvious drawbacks, as padding was initially added to decrease implementation complexity.
- val ciphertext = data.sliceArray(1 until data.size - 16)
- processPolyBytes(poly1305, ciphertext + UByteArray(((16U + ciphertext.size.toUInt() - block.size.toUInt()) % 16U).toInt()) { 0U } )
- val plaintext = ChaCha20Pure.xorWithKeystream(calcKey, calcNonce, ciphertext, 2U)
- val finalMac = associatedData.size.toULong().toLittleEndianUByteArray() + (ciphertext.size + 64).toULong().toLittleEndianUByteArray()
- processPolyBytes(poly1305, finalMac)
- val mac = poly1305.finalizeMac(polyBuffer.sliceArray(0 until polyBufferByteCounter))
- val expectedMac = data.sliceArray(data.size - 16 until data.size)
-
- if (expectedMac.contentEquals(mac).not()){
- throw InvalidTagException()
- }
- calcNonce.xorWithPositionsAndInsertIntoArray(0, 12, mac, 0, calcNonce, 0)
- return plaintext
- }
-
- fun cleanup() {
- key.overwriteWithZeroes()
- nonce.overwriteWithZeroes()
- calcKey.overwriteWithZeroes()
- calcNonce.overwriteWithZeroes()
- }
-
-
-
- private fun processPolyBytes(updateableMacPrimitive: Poly1305, data: UByteArray) {
- if (polyBufferByteCounter == 0) {
- val polyBlocks = data.size / 16
- val polyRemainder = data.size % 16
- for (i in 0 until polyBlocks) {
- updateableMacPrimitive.updateMac(data.sliceArray(i * 16 until i * 16 + 16))
- }
- if (polyRemainder != 0) {
- for (i in 0 until polyRemainder) {
- polyBuffer[i] = data[data.size - polyRemainder + i]
- }
- polyBufferByteCounter = polyRemainder
- }
- } else {
- if (polyBufferByteCounter + data.size < 16) {
- for (i in 0 until data.size) {
- polyBuffer[polyBufferByteCounter + i] = data[i]
- }
- polyBufferByteCounter += data.size
- } else {
- val borrowed = 16 - polyBufferByteCounter
- for (i in polyBufferByteCounter until 16) {
- polyBuffer[i] = data[i - polyBufferByteCounter]
- }
- updateableMacPrimitive.updateMac(polyBuffer)
- polyBufferByteCounter = 0
- val polyBlocks = (data.size - borrowed) / 16
- val polyRemainder = (data.size - borrowed) % 16
- for (i in 0 until polyBlocks) {
- updateableMacPrimitive.updateMac(data.sliceArray(borrowed + i * 16 until borrowed + i * 16 + 16))
- }
- if (polyRemainder != 0) {
- for (i in 0 until polyRemainder) {
- polyBuffer[i] = data[borrowed + i]
- }
- polyBufferByteCounter = polyRemainder
- }
- }
- }
- }
-
-
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bPure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bPure.kt
deleted file mode 100644
index 5e72b76..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bPure.kt
+++ /dev/null
@@ -1,351 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-import com.ionspin.kotlin.bignum.integer.BigInteger
-import com.ionspin.kotlin.bignum.integer.toBigInteger
-import com.ionspin.kotlin.crypto.*
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.rotateRight
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jul-2019
- */
-
-
-class Blake2bPure(val key: UByteArray? = null, val hashLength: Int = 64) : Blake2bMultipart {
-
- companion object : Blake2b {
- //Hack start
- //If this line is not included konanc 1.4-M1 fails to link because it cant find ByteArray which is
- //a backing class for UByteArray
- val byteArray: ByteArray = byteArrayOf(0, 1)
- //Hack end
- const val BITS_IN_WORD = 64
- const val ROUNDS_IN_COMPRESS = 12
- const val BLOCK_BYTES = 128
- override val MAX_HASH_BYTES = 64
- const val MIN_HASH_BYTES = 1
- const val MAX_KEY_BYTES = 64
- const val MIN_KEY_BYTES = 0
- val MAX_INPUT_BYTES = 2.toBigInteger() shl 128
-
- private val sigma = arrayOf(
- arrayOf(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15),
- arrayOf(14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3),
- arrayOf(11, 8, 12, 0, 5, 2, 15, 13, 10, 14, 3, 6, 7, 1, 9, 4),
- arrayOf(7, 9, 3, 1, 13, 12, 11, 14, 2, 6, 5, 10, 4, 0, 15, 8),
- arrayOf(9, 0, 5, 7, 2, 4, 10, 15, 14, 1, 11, 12, 6, 8, 3, 13),
- arrayOf(2, 12, 6, 10, 0, 11, 8, 3, 4, 13, 7, 5, 15, 14, 1, 9),
- arrayOf(12, 5, 1, 15, 14, 13, 4, 10, 0, 7, 6, 3, 9, 2, 8, 11),
- arrayOf(13, 11, 7, 14, 12, 1, 3, 9, 5, 0, 15, 4, 8, 6, 2, 10),
- arrayOf(6, 15, 14, 9, 11, 3, 0, 8, 12, 2, 13, 7, 1, 4, 10, 5),
- arrayOf(10, 2, 8, 4, 7, 6, 1, 5, 15, 11, 9, 14, 3, 12, 13, 0)
- )
-
-
- private val iv = arrayOf(
- 0X6A09E667F3BCC908UL,
- 0XBB67AE8584CAA73BUL,
- 0X3C6EF372FE94F82BUL,
- 0XA54FF53A5F1D36F1UL,
- 0X510E527FADE682D1UL,
- 0X9B05688C2B3E6C1FUL,
- 0X1F83D9ABFB41BD6BUL,
- 0X5BE0CD19137E2179UL
- )
-
- const val R1 = 32
- const val R2 = 24
- const val R3 = 16
- const val R4 = 63
-
- internal fun mixRound(input: Array, message: Array, round: Int): Array {
- var v = input
- val selectedSigma = sigma[round % 10]
- v = mix(v, 0, 4, 8, 12, message[selectedSigma[0]], message[selectedSigma[1]])
- v = mix(v, 1, 5, 9, 13, message[selectedSigma[2]], message[selectedSigma[3]])
- v = mix(v, 2, 6, 10, 14, message[selectedSigma[4]], message[selectedSigma[5]])
- v = mix(v, 3, 7, 11, 15, message[selectedSigma[6]], message[selectedSigma[7]])
- v = mix(v, 0, 5, 10, 15, message[selectedSigma[8]], message[selectedSigma[9]])
- v = mix(v, 1, 6, 11, 12, message[selectedSigma[10]], message[selectedSigma[11]])
- v = mix(v, 2, 7, 8, 13, message[selectedSigma[12]], message[selectedSigma[13]])
- v = mix(v, 3, 4, 9, 14, message[selectedSigma[14]], message[selectedSigma[15]])
- return v
-
- }
-
- private fun mix(v: Array, a: Int, b: Int, c: Int, d: Int, x: ULong, y: ULong): Array {
- v[a] = (v[a] + v[b] + x)
- v[d] = (v[d] xor v[a]) rotateRight R1
- v[c] = (v[c] + v[d])
- v[b] = (v[b] xor v[c]) rotateRight R2
- v[a] = (v[a] + v[b] + y)
- v[d] = (v[d] xor v[a]) rotateRight R3
- v[c] = (v[c] + v[d])
- v[b] = (v[b] xor v[c]) rotateRight R4
- return v
- }
-
- fun compress(
- h: Array,
- input: UByteArray,
- offsetCounter: BigInteger,
- finalBlock: Boolean
- ): Array {
- var v = Array(16) {
- when (it) {
- in 0..7 -> h[it]
- else -> iv[it - 8]
- }
- }
-
- val m = input.foldIndexed(Array(16) { 0UL }) { index, acc, byte ->
- val slot = index / 8
- val position = index % 8
- acc[slot] = acc[slot] + (byte.toULong() shl ((position) * 8))
- acc
- }
- if (Config.DEBUG) {
- val printout = m.map { it.toString(16) }.chunked(4)
- printout.forEach { println(it.joinToString(separator = " ") { it.toUpperCase() }) }
- println("Offset ${offsetCounter}")
- }
-
- v[12] = v[12] xor offsetCounter.ulongValue()
- v[13] = v[13] xor (offsetCounter shr BITS_IN_WORD).ulongValue()
-
- if (finalBlock) {
- v[14] = v[14].inv()
- }
-
- for (i in 0 until ROUNDS_IN_COMPRESS) {
- mixRound(v, m, i)
- }
-
- for (i in 0..7) {
- h[i] = h[i] xor v[i] xor v[i + 8]
- }
- return h
- }
-
-
- fun digest(inputString: String, key: String?, hashLength: Int): UByteArray {
- val array = inputString.encodeToUByteArray()
- val keyBytes = key?.run {
- encodeToUByteArray()
- } ?: ubyteArrayOf()
- return digest(inputMessage = array, key = keyBytes, hashLength = hashLength)
-
- }
-
- override fun digest(
- inputMessage: UByteArray,
- key: UByteArray,
- hashLength: Int
- ): UByteArray {
- if (hashLength > MAX_HASH_BYTES) {
- throw RuntimeException("Invalid hash length. Requested length more than maximum length. Requested length $hashLength")
- }
- val chunkedMessage = inputMessage.chunked(BLOCK_BYTES).map { it.toUByteArray() }.toTypedArray()
-
- val h = iv.copyOf()
-
- h[0] = h[0] xor 0x01010000UL xor (key.size.toULong() shl 8) xor hashLength.toULong()
-
-
- val message = if (key.isEmpty()) {
- if (chunkedMessage.isEmpty()) {
- Array(1) {
- UByteArray(128) {
- 0U
- }
- }
- } else {
- chunkedMessage
- }
- } else {
- arrayOf(padToBlock(key), *chunkedMessage)
- }
-
- if (message.size > 1) {
- for (i in 0 until message.size - 1) {
- compress(h, message[i], ((i + 1) * BLOCK_BYTES).toBigInteger(), false).copyInto(h)
- }
- }
-
- val lastSize = when (message.size) {
- 0 -> 0
- 1 -> message[message.size - 1].size
- else -> (message.size - 1) * BLOCK_BYTES + message[message.size - 1].size
-
- }
-
- val lastBlockPadded = if (message.isNotEmpty()) {
- padToBlock(message[message.size - 1])
- } else {
- UByteArray(16) { 0U }
- }
-
- compress(h, lastBlockPadded, lastSize.toBigInteger(), true).copyInto(h)
-
-
- return formatResult(h).copyOfRange(0, hashLength)
- }
-
- private fun formatResult(h: Array): UByteArray {
- return h.map {
- arrayOf(
- (it and 0xFFUL).toUByte(),
- (it shr 8 and 0xFFUL).toUByte(),
- (it shr 16 and 0xFFUL).toUByte(),
- (it shr 24 and 0xFFUL).toUByte(),
- (it shr 32 and 0xFFUL).toUByte(),
- (it shr 40 and 0xFFUL).toUByte(),
- (it shr 48 and 0xFFUL).toUByte(),
- (it shr 56 and 0xFFUL).toUByte()
- )
- }.flatMap {
- it.toList()
- }.toUByteArray()
- }
-
- private fun padToBlock(unpadded: UByteArray): UByteArray {
- if (unpadded.size == BLOCK_BYTES) {
- return unpadded
- }
-
- if (unpadded.size > BLOCK_BYTES) {
- throw IllegalStateException("Block larger than 128 bytes")
- }
-
- return UByteArray(BLOCK_BYTES) {
- when (it) {
- in 0 until unpadded.size -> unpadded[it]
- else -> 0U
- }
- }
-
- }
- }
-
- constructor(
- key: String?,
- requestedHashLenght: Int = 64
- ) : this(
- (key?.encodeToUByteArray() ?: ubyteArrayOf()),
- requestedHashLenght
- )
-
- override val MAX_HASH_BYTES: Int = Blake2bPure.MAX_HASH_BYTES
-
- var h = iv.copyOf()
- var counter = BigInteger.ZERO
- var bufferCounter = 0
- var buffer = UByteArray(BLOCK_BYTES) { 0U }
-
-
- init {
- h[0] = h[0] xor 0x01010000UL xor (key?.run { size.toULong() shl 8 } ?: 0UL) xor hashLength.toULong()
-
- if (!key.isNullOrEmpty()) {
- appendToBuffer(padToBlock(key), bufferCounter)
- }
- }
-
- override fun update(data: UByteArray) {
- if (data.isEmpty()) {
- throw RuntimeException("Updating with empty array is not allowed. If you need empty hash, just call digest without updating")
- }
-
- when {
- bufferCounter + data.size < BLOCK_BYTES -> appendToBuffer(data, bufferCounter)
- bufferCounter + data.size >= BLOCK_BYTES -> {
- val chunked = data.chunked(BLOCK_BYTES).map { it.toUByteArray() }
- chunked.forEach { chunk ->
- if (bufferCounter + chunk.size < BLOCK_BYTES) {
- appendToBuffer(chunk, bufferCounter)
- } else {
- chunk.copyInto(
- destination = buffer,
- destinationOffset = bufferCounter,
- startIndex = 0,
- endIndex = BLOCK_BYTES - bufferCounter
- )
- counter += BLOCK_BYTES
- consumeBlock(buffer)
- buffer = UByteArray(BLOCK_BYTES) {
- when (it) {
- in (0 until (chunk.size - (BLOCK_BYTES - bufferCounter))) -> {
- chunk[it + (BLOCK_BYTES - bufferCounter)]
- }
- else -> {
- 0U
- }
- }
-
- }
- bufferCounter = chunk.size - (BLOCK_BYTES - bufferCounter)
- }
- }
-
- }
- }
-
- }
-
- fun update(data: String) {
- update(data.encodeToUByteArray())
- }
-
- private fun appendToBuffer(array: UByteArray, start: Int) {
- array.copyInto(destination = buffer, destinationOffset = start, startIndex = 0, endIndex = array.size)
- bufferCounter += array.size
- }
-
- private fun consumeBlock(block: UByteArray) {
- h = compress(h, block, counter, false)
- }
-
- override fun digest(): UByteArray {
- val lastBlockPadded = padToBlock(buffer)
- counter += bufferCounter
- compress(h, lastBlockPadded, counter, true)
-
- val result = formatResult(h)
- reset()
- return result
-
- }
-
-
- private fun reset() {
- h = iv.copyOf()
- counter = BigInteger.ZERO
- bufferCounter = 0
- buffer = UByteArray(BLOCK_BYTES) { 0U }
- }
-
-
-}
-
-
-
-
-
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Pure.kt
deleted file mode 100644
index eda11e8..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Pure.kt
+++ /dev/null
@@ -1,328 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.rotateRight
-
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-
-
-class Sha256Pure : Sha256 {
-
- override val MAX_HASH_BYTES: Int = 32
-
-
- companion object : StatelessSha256 {
- const val BLOCK_SIZE = 512
- const val BLOCK_SIZE_IN_BYTES = 64
- const val UINT_MASK = 0xFFFFFFFFU
- const val BYTE_MASK_FROM_ULONG = 0xFFUL
- const val BYTE_MASK_FROM_UINT = 0xFFU
-
- override val MAX_HASH_BYTES: Int = 32
-
- val iv = arrayOf(
- 0x6a09e667U,
- 0xbb67ae85U,
- 0x3c6ef372U,
- 0xa54ff53aU,
- 0x510e527fU,
- 0x9b05688cU,
- 0x1f83d9abU,
- 0x5be0cd19U
- )
-
- val k = arrayOf(
- 0x428a2f98U, 0x71374491U, 0xb5c0fbcfU, 0xe9b5dba5U, 0x3956c25bU, 0x59f111f1U, 0x923f82a4U, 0xab1c5ed5U,
- 0xd807aa98U, 0x12835b01U, 0x243185beU, 0x550c7dc3U, 0x72be5d74U, 0x80deb1feU, 0x9bdc06a7U, 0xc19bf174U,
- 0xe49b69c1U, 0xefbe4786U, 0x0fc19dc6U, 0x240ca1ccU, 0x2de92c6fU, 0x4a7484aaU, 0x5cb0a9dcU, 0x76f988daU,
- 0x983e5152U, 0xa831c66dU, 0xb00327c8U, 0xbf597fc7U, 0xc6e00bf3U, 0xd5a79147U, 0x06ca6351U, 0x14292967U,
- 0x27b70a85U, 0x2e1b2138U, 0x4d2c6dfcU, 0x53380d13U, 0x650a7354U, 0x766a0abbU, 0x81c2c92eU, 0x92722c85U,
- 0xa2bfe8a1U, 0xa81a664bU, 0xc24b8b70U, 0xc76c51a3U, 0xd192e819U, 0xd6990624U, 0xf40e3585U, 0x106aa070U,
- 0x19a4c116U, 0x1e376c08U, 0x2748774cU, 0x34b0bcb5U, 0x391c0cb3U, 0x4ed8aa4aU, 0x5b9cca4fU, 0x682e6ff3U,
- 0x748f82eeU, 0x78a5636fU, 0x84c87814U, 0x8cc70208U, 0x90befffaU, 0xa4506cebU, 0xbef9a3f7U, 0xc67178f2U
- )
-
-
- override fun digest(inputMessage: UByteArray): UByteArray {
-
- var h = iv.copyOf()
-
- val expansionArray = createExpansionArray(inputMessage.size.toLong())
-
- val chunks = (
- inputMessage +
- expansionArray +
- (inputMessage.size * 8).toULong().toPaddedByteArray()
- )
- .chunked(BLOCK_SIZE_IN_BYTES)
-
- chunks.forEach { chunk ->
- val w = expandChunk(chunk.toUByteArray())
- mix(h, w).copyInto(h)
-
- }
-
- val digest = h[0].toPaddedByteArray() +
- h[1].toPaddedByteArray() +
- h[2].toPaddedByteArray() +
- h[3].toPaddedByteArray() +
- h[4].toPaddedByteArray() +
- h[5].toPaddedByteArray() +
- h[6].toPaddedByteArray() +
- h[7].toPaddedByteArray()
- return digest
- }
-
- private fun scheduleSigma0(value: UInt): UInt {
- return value.rotateRight(7) xor value.rotateRight(18) xor (value shr 3)
- }
-
- private fun scheduleSigma1(value: UInt): UInt {
- return value.rotateRight(17) xor value.rotateRight(19) xor (value shr 10)
- }
-
- private fun compressionSigma0(a: UInt): UInt {
- return (a rotateRight 2) xor (a rotateRight 13) xor (a rotateRight 22)
- }
-
- private fun compressionSigma1(e: UInt): UInt {
- return (e rotateRight 6) xor (e rotateRight 11) xor (e rotateRight 25)
- }
-
- private fun ch(x: UInt, y: UInt, z: UInt): UInt {
- return ((x and y) xor ((x xor UINT_MASK) and z))
- }
-
- private fun maj(x: UInt, y: UInt, z: UInt): UInt {
- return (((x and y) xor (x and z) xor (y and z)))
- }
-
- private fun expandChunk(chunk: UByteArray): Array {
- val w = Array(BLOCK_SIZE_IN_BYTES) {
- when (it) {
- in 0 until 16 -> {
- var collected = (chunk[(it * 4)].toUInt() shl 24) +
- (chunk[(it * 4) + 1].toUInt() shl 16) +
- (chunk[(it * 4) + 2].toUInt() shl 8) +
- (chunk[(it * 4) + 3].toUInt())
- collected
- }
- else -> 0U
- }
- }
- for (i in 16 until BLOCK_SIZE_IN_BYTES) {
- val s0 = scheduleSigma0(w[i - 15])
- val s1 = scheduleSigma1(w[i - 2])
- w[i] = w[i - 16] + s0 + w[i - 7] + s1
- }
- return w
- }
-
- private fun mix(h: Array, w: Array): Array {
- var paramA = h[0]
- var paramB = h[1]
- var paramC = h[2]
- var paramD = h[3]
- var paramE = h[4]
- var paramF = h[5]
- var paramG = h[6]
- var paramH = h[7]
-
- for (i in 0 until BLOCK_SIZE_IN_BYTES) {
- val s1 = compressionSigma1(paramE)
- val ch = ch(paramE, paramF, paramG)
- val temp1 = paramH + s1 + ch + k[i] + w[i]
- val s0 = compressionSigma0(paramA)
- val maj = maj(paramA, paramB, paramC)
- val temp2 = s0 + maj
- paramH = paramG
- paramG = paramF
- paramF = paramE
- paramE = paramD + temp1
- paramD = paramC
- paramC = paramB
- paramB = paramA
- paramA = temp1 + temp2
- }
-
- h[0] += paramA
- h[1] += paramB
- h[2] += paramC
- h[3] += paramD
- h[4] += paramE
- h[5] += paramF
- h[6] += paramG
- h[7] += paramH
- return h
- }
-
-
- fun createExpansionArray(originalSizeInBytes: Long): UByteArray {
- val originalMessageSizeInBits = originalSizeInBytes * 8
-
-
- //K such that L + 1 + K + 64 is a multiple of 512
- val expandedRemainderOf512 = (originalMessageSizeInBits + BLOCK_SIZE_IN_BYTES + 1) % BLOCK_SIZE
- val zeroAddAmount = when (expandedRemainderOf512) {
- 0L -> 0
- else -> ((BLOCK_SIZE - expandedRemainderOf512) / 8).toInt()
- }
- val expansionArray = UByteArray(zeroAddAmount + 1) {
- when (it) {
- 0 -> 0b10000000U
- else -> 0U
- }
- }
- return expansionArray
- }
-
- private fun ULong.toPaddedByteArray(): UByteArray {
- val byteMask = BYTE_MASK_FROM_ULONG
- return UByteArray(8) {
- when (it) {
- 7 -> (this and byteMask).toUByte()
- 6 -> ((this shr 8) and byteMask).toUByte()
- 5 -> ((this shr 16) and byteMask).toUByte()
- 4 -> ((this shr 24) and byteMask).toUByte()
- 3 -> ((this shr 32) and byteMask).toUByte()
- 2 -> ((this shr 40) and byteMask).toUByte()
- 1 -> ((this shr 48) and byteMask).toUByte()
- 0 -> ((this shr 54) and byteMask).toUByte()
- else -> throw RuntimeException("Invalid conversion")
- }
- }
- }
-
- private fun UInt.toPaddedByteArray(): UByteArray {
- val byteMask = BYTE_MASK_FROM_UINT
- return UByteArray(4) {
- when (it) {
- 3 -> (this and byteMask).toUByte()
- 2 -> ((this shr 8) and byteMask).toUByte()
- 1 -> ((this shr 16) and byteMask).toUByte()
- 0 -> ((this shr 24) and byteMask).toUByte()
- else -> throw RuntimeException("Invalid conversion")
- }
- }
- }
-
- }
-
- var h = iv.copyOf()
- var counter = 0L
- var bufferCounter = 0
- var buffer = UByteArray(BLOCK_SIZE_IN_BYTES) { 0U }
- var digested = false
-
-
- fun update(data: String) {
- if (digested) {
- throw RuntimeException("This instance of updateable SHA256 was already finished once. You should use new instance")
- }
- return update(data.encodeToUByteArray())
- }
-
- override fun update(data: UByteArray) {
- if (data.isEmpty()) {
- throw RuntimeException("Updating with empty array is not allowed. If you need empty hash, just call digest without updating")
- }
-
- when {
- bufferCounter + data.size < BLOCK_SIZE_IN_BYTES -> appendToBuffer(data, bufferCounter)
- bufferCounter + data.size == BLOCK_SIZE_IN_BYTES -> {
- counter += BLOCK_SIZE_IN_BYTES
- consumeBlock(data)
- }
- bufferCounter + data.size == BLOCK_SIZE_IN_BYTES -> {
- counter += BLOCK_SIZE_IN_BYTES
- consumeBlock(data)
- }
- bufferCounter + data.size >= BLOCK_SIZE_IN_BYTES -> {
- val chunked = data.chunked(BLOCK_SIZE_IN_BYTES)
- chunked.forEach { chunk ->
- if (bufferCounter + chunk.size < BLOCK_SIZE_IN_BYTES) {
- appendToBuffer(chunk.toUByteArray(), bufferCounter)
- } else {
- chunk.toUByteArray().copyInto(
- destination = buffer,
- destinationOffset = bufferCounter,
- startIndex = 0,
- endIndex = BLOCK_SIZE_IN_BYTES - bufferCounter
- )
- counter += BLOCK_SIZE_IN_BYTES
- consumeBlock(buffer)
- buffer = UByteArray(BLOCK_SIZE_IN_BYTES) {
- when (it) {
- in (0 until (chunk.size - (BLOCK_SIZE_IN_BYTES - bufferCounter))) -> {
- chunk[it + (BLOCK_SIZE_IN_BYTES - bufferCounter)]
- }
- else -> {
- 0U
- }
- }
-
- }
- bufferCounter = chunk.size - (BLOCK_SIZE_IN_BYTES - bufferCounter)
- }
- }
-
- }
- }
- }
-
- private fun consumeBlock(block: UByteArray) {
- val w = expandChunk(block)
- mix(h, w).copyInto(h)
- }
-
- override fun digest(): UByteArray {
- val length = counter + bufferCounter
- val expansionArray = createExpansionArray(length)
- val finalBlock =
- buffer.copyOfRange(0, bufferCounter) + expansionArray + (length * 8).toULong().toPaddedByteArray()
- finalBlock.chunked(BLOCK_SIZE_IN_BYTES).forEach {
- consumeBlock(it.toUByteArray())
- }
-
-
- val digest = h[0].toPaddedByteArray() +
- h[1].toPaddedByteArray() +
- h[2].toPaddedByteArray() +
- h[3].toPaddedByteArray() +
- h[4].toPaddedByteArray() +
- h[5].toPaddedByteArray() +
- h[6].toPaddedByteArray() +
- h[7].toPaddedByteArray()
- digested = true
- return digest
- }
-
- private fun appendToBuffer(array: UByteArray, start: Int) {
- array.copyInto(destination = buffer, destinationOffset = start, startIndex = 0, endIndex = array.size)
- bufferCounter += array.size
- }
-
-
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Pure.kt
deleted file mode 100644
index 2aba3af..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Pure.kt
+++ /dev/null
@@ -1,394 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.rotateRight
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 18-Jul-2019
- */
-
-
-class Sha512Pure : Sha512Multipart {
-
- override val MAX_HASH_BYTES: Int = 32
-
- companion object : Sha512 {
- const val BLOCK_SIZE = 1024
- const val BLOCK_SIZE_IN_BYTES = 128
- const val CHUNK_SIZE = 80
- const val ULONG_MASK = 0xFFFFFFFFFFFFFFFFUL
-
- override val MAX_HASH_BYTES: Int = 32
-
- val k = arrayOf(
- 0x428a2f98d728ae22UL,
- 0x7137449123ef65cdUL,
- 0xb5c0fbcfec4d3b2fUL,
- 0xe9b5dba58189dbbcUL,
- 0x3956c25bf348b538UL,
- 0x59f111f1b605d019UL,
- 0x923f82a4af194f9bUL,
- 0xab1c5ed5da6d8118UL,
- 0xd807aa98a3030242UL,
- 0x12835b0145706fbeUL,
- 0x243185be4ee4b28cUL,
- 0x550c7dc3d5ffb4e2UL,
- 0x72be5d74f27b896fUL,
- 0x80deb1fe3b1696b1UL,
- 0x9bdc06a725c71235UL,
- 0xc19bf174cf692694UL,
- 0xe49b69c19ef14ad2UL,
- 0xefbe4786384f25e3UL,
- 0x0fc19dc68b8cd5b5UL,
- 0x240ca1cc77ac9c65UL,
- 0x2de92c6f592b0275UL,
- 0x4a7484aa6ea6e483UL,
- 0x5cb0a9dcbd41fbd4UL,
- 0x76f988da831153b5UL,
- 0x983e5152ee66dfabUL,
- 0xa831c66d2db43210UL,
- 0xb00327c898fb213fUL,
- 0xbf597fc7beef0ee4UL,
- 0xc6e00bf33da88fc2UL,
- 0xd5a79147930aa725UL,
- 0x06ca6351e003826fUL,
- 0x142929670a0e6e70UL,
- 0x27b70a8546d22ffcUL,
- 0x2e1b21385c26c926UL,
- 0x4d2c6dfc5ac42aedUL,
- 0x53380d139d95b3dfUL,
- 0x650a73548baf63deUL,
- 0x766a0abb3c77b2a8UL,
- 0x81c2c92e47edaee6UL,
- 0x92722c851482353bUL,
- 0xa2bfe8a14cf10364UL,
- 0xa81a664bbc423001UL,
- 0xc24b8b70d0f89791UL,
- 0xc76c51a30654be30UL,
- 0xd192e819d6ef5218UL,
- 0xd69906245565a910UL,
- 0xf40e35855771202aUL,
- 0x106aa07032bbd1b8UL,
- 0x19a4c116b8d2d0c8UL,
- 0x1e376c085141ab53UL,
- 0x2748774cdf8eeb99UL,
- 0x34b0bcb5e19b48a8UL,
- 0x391c0cb3c5c95a63UL,
- 0x4ed8aa4ae3418acbUL,
- 0x5b9cca4f7763e373UL,
- 0x682e6ff3d6b2b8a3UL,
- 0x748f82ee5defb2fcUL,
- 0x78a5636f43172f60UL,
- 0x84c87814a1f0ab72UL,
- 0x8cc702081a6439ecUL,
- 0x90befffa23631e28UL,
- 0xa4506cebde82bde9UL,
- 0xbef9a3f7b2c67915UL,
- 0xc67178f2e372532bUL,
- 0xca273eceea26619cUL,
- 0xd186b8c721c0c207UL,
- 0xeada7dd6cde0eb1eUL,
- 0xf57d4f7fee6ed178UL,
- 0x06f067aa72176fbaUL,
- 0x0a637dc5a2c898a6UL,
- 0x113f9804bef90daeUL,
- 0x1b710b35131c471bUL,
- 0x28db77f523047d84UL,
- 0x32caab7b40c72493UL,
- 0x3c9ebe0a15c9bebcUL,
- 0x431d67c49c100d4cUL,
- 0x4cc5d4becb3e42b6UL,
- 0x597f299cfc657e2aUL,
- 0x5fcb6fab3ad6faecUL,
- 0x6c44198c4a475817UL
- )
-
- val iv = arrayOf(
- 0x6a09e667f3bcc908UL,
- 0xbb67ae8584caa73bUL,
- 0x3c6ef372fe94f82bUL,
- 0xa54ff53a5f1d36f1UL,
- 0x510e527fade682d1UL,
- 0x9b05688c2b3e6c1fUL,
- 0x1f83d9abfb41bd6bUL,
- 0x5be0cd19137e2179UL
- )
-
-
- override fun digest(inputMessage: UByteArray): UByteArray {
-
- var h = iv.copyOf()
-
- val expansionArray = createExpansionArray(inputMessage.size.toLong())
-
- val chunks =
- (inputMessage + expansionArray + (inputMessage.size * 8).toULong().toPadded128BitByteArray()).chunked(
- BLOCK_SIZE_IN_BYTES
- )
-
- chunks.forEach { chunk ->
- val w = expandChunk(chunk.toUByteArray())
- mix(h, w)
-
- }
-
- val digest =
- h[0].toPaddedByteArray() +
- h[1].toPaddedByteArray() +
- h[2].toPaddedByteArray() +
- h[3].toPaddedByteArray() +
- h[4].toPaddedByteArray() +
- h[5].toPaddedByteArray() +
- h[6].toPaddedByteArray() +
- h[7].toPaddedByteArray()
- return digest
- }
-
- private fun scheduleSigma0(value: ULong): ULong {
- return value.rotateRight(1) xor value.rotateRight(8) xor (value shr 7)
- }
-
- private fun scheduleSigma1(value: ULong): ULong {
- return value.rotateRight(19) xor value.rotateRight(61) xor (value shr 6)
- }
-
- private fun compressionSigma0(e: ULong): ULong {
- return (e rotateRight 28) xor (e rotateRight 34) xor (e rotateRight 39)
- }
-
- private fun compressionSigma1(a: ULong): ULong {
- return (a rotateRight 14) xor (a rotateRight 18) xor (a rotateRight 41)
- }
-
- private fun ch(x: ULong, y: ULong, z: ULong): ULong {
- return ((x and y) xor ((x xor ULONG_MASK) and z))
- }
-
- private fun maj(x: ULong, y: ULong, z: ULong): ULong {
- return ((x and y) xor (x and z) xor (y and z))
- }
-
- private fun expandChunk(chunk: UByteArray): Array {
- val w = Array(CHUNK_SIZE) {
- when (it) {
- in 0 until 16 -> {
- var collected = (chunk[(it * 8)].toULong() shl 56) +
- (chunk[(it * 8) + 1].toULong() shl 48) +
- (chunk[(it * 8) + 2].toULong() shl 40) +
- (chunk[(it * 8) + 3].toULong() shl 32) +
- (chunk[(it * 8) + 4].toULong() shl 24) +
- (chunk[(it * 8) + 5].toULong() shl 16) +
- (chunk[(it * 8) + 6].toULong() shl 8) +
- (chunk[(it * 8) + 7].toULong())
- collected
- }
- else -> 0UL
- }
- }
- for (i in 16 until CHUNK_SIZE) {
- val s0 = scheduleSigma0(w[i - 15])
- val s1 = scheduleSigma1(w[i - 2])
- w[i] = w[i - 16] + s0 + w[i - 7] + s1
- }
- return w
- }
-
- private fun mix(h: Array, w: Array): Array {
- var paramA = h[0]
- var paramB = h[1]
- var paramC = h[2]
- var paramD = h[3]
- var paramE = h[4]
- var paramF = h[5]
- var paramG = h[6]
- var paramH = h[7]
-
- for (i in 0 until CHUNK_SIZE) {
- val s1 = compressionSigma1(paramE)
- val ch = ch(paramE, paramF, paramG)
- val temp1 = paramH + s1 + ch + k[i] + w[i]
- val s0 = compressionSigma0(paramA)
- val maj = maj(paramA, paramB, paramC)
- val temp2 = s0 + maj
- paramH = paramG
- paramG = paramF
- paramF = paramE
- paramE = paramD + temp1
- paramD = paramC
- paramC = paramB
- paramB = paramA
- paramA = temp1 + temp2
- }
-
- h[0] += paramA
- h[1] += paramB
- h[2] += paramC
- h[3] += paramD
- h[4] += paramE
- h[5] += paramF
- h[6] += paramG
- h[7] += paramH
- return h
- }
-
- fun createExpansionArray(originalSizeInBytes: Long): UByteArray {
- val originalMessageSizeInBits = originalSizeInBytes * 8
-
- val expandedRemainderOf1024 = (originalMessageSizeInBits + 129) % BLOCK_SIZE
- val zeroAddAmount = when (expandedRemainderOf1024) {
- 0L -> 0
- else -> ((BLOCK_SIZE - expandedRemainderOf1024) / 8).toInt()
- }
- val expansionArray = UByteArray(zeroAddAmount + 1) {
- when (it) {
- 0 -> 0b10000000U
- else -> 0U
- }
- }
- return expansionArray
- }
-
-
- private fun ULong.toPaddedByteArray(): UByteArray {
- val byteMask = 0xFFUL
- //Ignore messages longer than 64 bits for now
- return UByteArray(8) {
- when (it) {
- 7 -> (this and byteMask).toUByte()
- 6 -> ((this shr 8) and byteMask).toUByte()
- 5 -> ((this shr 16) and byteMask).toUByte()
- 4 -> ((this shr 24) and byteMask).toUByte()
- 3 -> ((this shr 32) and byteMask).toUByte()
- 2 -> ((this shr 40) and byteMask).toUByte()
- 1 -> ((this shr 48) and byteMask).toUByte()
- 0 -> ((this shr 56) and byteMask).toUByte()
- else -> 0U
- }
- }
- }
-
- private fun ULong.toPadded128BitByteArray(): UByteArray {
- val byteMask = 0xFFUL
- //Ignore messages longer than 64 bits for now
- return UByteArray(16) {
- when (it) {
- 15 -> (this and byteMask).toUByte()
- 14 -> ((this shr 8) and byteMask).toUByte()
- 13 -> ((this shr 16) and byteMask).toUByte()
- 12 -> ((this shr 24) and byteMask).toUByte()
- 11 -> ((this shr 32) and byteMask).toUByte()
- 10 -> ((this shr 40) and byteMask).toUByte()
- 9 -> ((this shr 48) and byteMask).toUByte()
- 8 -> ((this shr 54) and byteMask).toUByte()
- else -> 0U
- }
- }
- }
- }
-
- var h = iv.copyOf()
- var counter = 0L
- var bufferCounter = 0
- var buffer = UByteArray(BLOCK_SIZE_IN_BYTES) { 0U }
- var digested = false
-
-
- fun update(data: String) {
- return update(data.encodeToUByteArray())
- }
-
- override fun update(data: UByteArray) {
- if (data.isEmpty()) {
- throw RuntimeException("Updating with empty array is not allowed. If you need empty hash, just call digest without updating")
- }
- if (digested) {
- throw RuntimeException("This instance of updateable SHA256 was already finished once. You should use new instance")
- }
-
- when {
- bufferCounter + data.size < BLOCK_SIZE_IN_BYTES -> appendToBuffer(data, bufferCounter)
- bufferCounter + data.size >= BLOCK_SIZE_IN_BYTES -> {
- val chunked = data.chunked(BLOCK_SIZE_IN_BYTES)
- chunked.forEach { chunk ->
- if (bufferCounter + chunk.size < BLOCK_SIZE_IN_BYTES) {
- appendToBuffer(chunk.toUByteArray(), bufferCounter)
- } else {
- chunk.toUByteArray().copyInto(
- destination = buffer,
- destinationOffset = bufferCounter,
- startIndex = 0,
- endIndex = BLOCK_SIZE_IN_BYTES - bufferCounter
- )
- counter += BLOCK_SIZE_IN_BYTES
- consumeBlock(buffer)
- buffer = UByteArray(BLOCK_SIZE_IN_BYTES) {
- when (it) {
- in (0 until (chunk.size - (BLOCK_SIZE_IN_BYTES - bufferCounter))) -> {
- chunk[it + (BLOCK_SIZE_IN_BYTES - bufferCounter)]
- }
- else -> {
- 0U
- }
- }
-
- }
- bufferCounter = chunk.size - (BLOCK_SIZE_IN_BYTES - bufferCounter)
- }
- }
-
- }
- }
- }
-
- private fun consumeBlock(block: UByteArray) {
- val w = expandChunk(block)
- mix(h, w).copyInto(h)
- }
-
- override fun digest(): UByteArray {
- val length = counter + bufferCounter
- val expansionArray = createExpansionArray(length)
- val finalBlock =
- buffer.copyOfRange(0, bufferCounter) + expansionArray + (length * 8).toULong().toPadded128BitByteArray()
- finalBlock.chunked(BLOCK_SIZE_IN_BYTES).forEach {
- consumeBlock(it.toUByteArray())
- }
-
-
- val digest = h[0].toPaddedByteArray() +
- h[1].toPaddedByteArray() +
- h[2].toPaddedByteArray() +
- h[3].toPaddedByteArray() +
- h[4].toPaddedByteArray() +
- h[5].toPaddedByteArray() +
- h[6].toPaddedByteArray() +
- h[7].toPaddedByteArray()
- digested = true
- return digest
- }
-
- private fun appendToBuffer(array: UByteArray, start: Int) {
- array.copyInto(destination = buffer, destinationOffset = start, startIndex = 0, endIndex = array.size)
- bufferCounter += array.size
- }
-
-
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2.kt
deleted file mode 100644
index 707a664..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2.kt
+++ /dev/null
@@ -1,10 +0,0 @@
-package com.ionspin.kotlin.crypto.keyderivation.argon2
-
-import com.ionspin.kotlin.crypto.keyderivation.KeyDerivationFunction
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 24-May-2020
- */
-interface Argon2 : KeyDerivationFunction
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Exceptions.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Exceptions.kt
deleted file mode 100644
index 57c7ed4..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Exceptions.kt
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.keyderivation.argon2
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-May-2020
- */
-class Argon2TagTooShort(tagLength: UInt) : RuntimeException("Too short tag (output) requested. Requested: $tagLength")
-class Argon2TagTooLong(tagLength: UInt) : RuntimeException("Too long tag (output) requested. Requested: $tagLength")
-class Argon2TimeTooShort(iterations: Int) : RuntimeException("Too short time parameter (Too few iterations). Requested iterations: $iterations")
-class Argon2TimeTooLong(iterations: Int) : RuntimeException("Too long time parameter (Too many iterations). Requested iterations: $iterations")
-class Argon2MemoryTooLitlle(requestedMemorySize: UInt) : RuntimeException("Requested memory size must be larger than 8 * parallelism. Requested size: $requestedMemorySize")
-class Argon2MemoryTooMuch(requestedMemorySize: UInt) : RuntimeException("Requested memory size too large. Requested size: $requestedMemorySize")
-class Argon2LanesTooFew(parallelism: Int) : RuntimeException("Too few, or invalid number of threads requested $parallelism")
-class Argon2LanesTooMany(parallelism: Int) : RuntimeException("Too many threads requested (parallelism). Requested: $parallelism")
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Pure.kt
deleted file mode 100644
index f32883f..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Pure.kt
+++ /dev/null
@@ -1,401 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_API_USAGE", "EXPERIMENTAL_UNSIGNED_LITERALS")
-
-package com.ionspin.kotlin.crypto.keyderivation.argon2
-
-import com.ionspin.kotlin.bignum.integer.toBigInteger
-
-import com.ionspin.kotlin.crypto.SRNG
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bPure
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.keyderivation.ArgonResult
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Utils.argonBlake2bArbitraryLenghtHash
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Utils.compressionFunctionG
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Utils.validateArgonParameters
-import com.ionspin.kotlin.crypto.util.*
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-May-2020
- */
-
-enum class ArgonType(val typeId: Int) {
- Argon2d(0), Argon2i(1), Argon2id(2)
-}
-
-data class SegmentPosition(
- val iteration: Int,
- val lane: Int,
- val slice: Int
-)
-
-
-
-
-
-
-class Argon2Pure(
- private val password: UByteArray,
- private val salt: UByteArray = ubyteArrayOf(),
- private val parallelism: Int = 1,
- private val tagLength: UInt = 64U,
- requestedMemorySize: UInt = 0U,
- private val numberOfIterations: Int = 1,
- private val key: UByteArray = ubyteArrayOf(),
- private val associatedData: UByteArray = ubyteArrayOf(),
- private val argonType: ArgonType = ArgonType.Argon2id
-) : Argon2 {
-
- companion object {
- fun derive(
- password: String,
- salt: String? = null,
- key: String,
- associatedData: String,
- parallelism: Int = 16,
- tagLength: Int = 64,
- memory: Int = 4096,
- numberOfIterations: Int = 10,
- ): ArgonResult {
- val salt = SRNG.getRandomBytes(64)
- val argon = Argon2Pure(
- password.encodeToUByteArray(),
- salt,
- parallelism,
- tagLength.toUInt(),
- memory.toUInt(),
- numberOfIterations,
- key.encodeToUByteArray(),
- associatedData.encodeToUByteArray(),
- ArgonType.Argon2id
- )
- val resultArray = argon.derive()
- return ArgonResult(resultArray, salt)
- }
- }
-
- constructor(
- password: String,
- salt: String = "",
- parallelism: Int = 1,
- tagLength: UInt = 64U,
- requestedMemorySize: UInt = 0U,
- numberOfIterations: Int = 10,
- key: String = "",
- associatedData: String = "",
- argonType: ArgonType = ArgonType.Argon2id
- ) : this(
- password.encodeToUByteArray(),
- salt.encodeToUByteArray(),
- parallelism,
- tagLength,
- requestedMemorySize,
- numberOfIterations,
- key.encodeToUByteArray(),
- associatedData.encodeToUByteArray(),
- argonType
- )
-
- //We support only the latest version
- private val versionNumber: UInt = 0x13U
-
- //Use either requested memory size, or default, or throw exception if the requested amount is less than 8*parallelism
- private val memorySize = if (requestedMemorySize == 0U) {
- ((8 * parallelism) * 2).toUInt()
- } else {
- requestedMemorySize
- }
- private val blockCount = (memorySize / (4U * parallelism.toUInt())) * (4U * parallelism.toUInt())
- private val columnCount = (blockCount / parallelism.toUInt()).toInt()
- private val segmentLength = columnCount / 4
-
- private val useIndependentAddressing = argonType == ArgonType.Argon2id || argonType == ArgonType.Argon2i
-
- // State
- private val matrix: ArgonMatrix
-
- init {
- matrix = ArgonMatrix(columnCount, parallelism)
- validateArgonParameters(
- password,
- salt,
- parallelism,
- tagLength,
- requestedMemorySize,
- numberOfIterations,
- key,
- associatedData,
- argonType
- )
- }
-
-
-
- private fun populateAddressBlock(
- iteration: Int,
- slice: Int,
- lane: Int,
- addressBlock: ArgonBlockPointer,
- addressCounter: ULong
- ): ArgonBlockPointer {
- //Calculate first pass
- val zeroesBlock = ArgonBlock()
- val firstPass = compressionFunctionG(
- zeroesBlock.getBlockPointer(),
- ArgonBlock(iteration.toULong().toLittleEndianUByteArray() +
- lane.toULong().toLittleEndianUByteArray() +
- slice.toULong().toLittleEndianUByteArray() +
- blockCount.toULong().toLittleEndianUByteArray() +
- numberOfIterations.toULong().toLittleEndianUByteArray() +
- argonType.typeId.toULong().toLittleEndianUByteArray() +
- addressCounter.toLittleEndianUByteArray() +
- UByteArray(968) { 0U }
- ).getBlockPointer(),
- addressBlock,
- false
- )
- val secondPass = compressionFunctionG(
- zeroesBlock.getBlockPointer(),
- firstPass,
- firstPass,
- false
- )
- return secondPass
- }
-
-
- private fun computeReferenceBlockIndexes(
- iteration: Int,
- slice: Int,
- lane: Int,
- column: Int,
- addressBlockPointer: ArgonBlockPointer?
- ): Pair {
-
- val segmentIndex = (column % segmentLength)
- val independentIndex = segmentIndex % 128 // 128 is the number of addresses in address block
- val (j1, j2) = when (argonType) {
- ArgonType.Argon2d -> {
- val previousBlockStart = if (column == 0) {
- matrix.getBlockPointer(lane, columnCount - 1) //Get last block in the SAME lane
- } else {
- matrix.getBlockPointer(lane, column - 1)
- }
- val first32Bit = matrix.sliceArray(previousBlockStart.asInt() until previousBlockStart.asInt() + 4).fromLittleEndianArrayToUInt()
- val second32Bit = matrix.sliceArray(previousBlockStart.asInt() + 4 until previousBlockStart.asInt() + 8).fromLittleEndianArrayToUInt()
-
- Pair(first32Bit, second32Bit)
- }
- ArgonType.Argon2i -> {
- val first32Bit = addressBlockPointer!!.getUIntFromPosition(independentIndex * 8)
- val second32Bit = addressBlockPointer!!.getUIntFromPosition(independentIndex * 8 + 4)
- Pair(first32Bit, second32Bit)
- }
- ArgonType.Argon2id -> {
- if (iteration == 0 && (slice == 0 || slice == 1)) {
- val first32Bit = addressBlockPointer!!.getUIntFromPosition(independentIndex * 8)
- val second32Bit = addressBlockPointer!!.getUIntFromPosition(independentIndex * 8 + 4)
- Pair(first32Bit, second32Bit)
- } else {
- val previousBlockStart = if (column == 0) {
- matrix.getBlockPointer(lane, columnCount - 1) //Get last block in the SAME lane
- } else {
- matrix.getBlockPointer(lane, column - 1)
- }
- val first32Bit = matrix.sliceArray(previousBlockStart.asInt() until previousBlockStart.asInt() + 4).fromLittleEndianArrayToUInt()
- val second32Bit = matrix.sliceArray(previousBlockStart.asInt() + 4 until previousBlockStart.asInt() + 8).fromLittleEndianArrayToUInt()
- Pair(first32Bit, second32Bit)
- }
-
- }
- }
-
- //If this is first iteration and first slice, block is taken from the current lane
- val l = if (iteration == 0 && slice == 0) {
- lane
- } else {
- (j2.toBigInteger() % parallelism).intValue()
-
- }
-
-
- val referenceAreaSize = if (iteration == 0) {
- if (slice == 0) {
- //All indices except the previous
- segmentIndex - 1
- } else {
- if (lane == l) {
- //Same lane
- column - 1
- } else {
- slice * (columnCount / 4) + if (segmentIndex == 0) { // Check if column is first block of the SEGMENT
- -1
- } else {
- 0
- }
- }
- }
- } else {
- if (lane == l) {
- columnCount - (columnCount / 4) + (segmentIndex - 1)
- } else {
- columnCount - (columnCount / 4) + if (segmentIndex == 0) {
- -1
- } else {
- 0
- }
- }
- }
-
- val x = (j1.toULong() * j1) shr 32
- val y = (referenceAreaSize.toULong() * x) shr 32
- val z = referenceAreaSize.toULong() - 1U - y
-
- val startPosition = if (iteration == 0) {
- 0
- } else {
- if (slice == 3) {
- 0
- } else {
- (slice + 1) * segmentLength
- }
- }
- val absolutePosition = (startPosition + z.toInt()) % columnCount
-
- return Pair(l, absolutePosition)
- }
-
- override fun derive(): UByteArray {
- val blakeInput = parallelism.toUInt().toLittleEndianUByteArray() +
- tagLength.toLittleEndianUByteArray() +
- memorySize.toLittleEndianUByteArray() +
- numberOfIterations.toUInt().toLittleEndianUByteArray() +
- versionNumber.toLittleEndianUByteArray() +
- argonType.typeId.toUInt().toLittleEndianUByteArray() +
- password.size.toUInt().toLittleEndianUByteArray() + password +
- salt.size.toUInt().toLittleEndianUByteArray() + salt +
- key.size.toUInt().toLittleEndianUByteArray() + key +
- associatedData.size.toUInt().toLittleEndianUByteArray() + associatedData
- val h0 = Blake2bPure.digest(
- blakeInput
- )
-
- //Compute B[i][0]
- for (i in 0 until parallelism) {
- matrix.setBlockAt(i, 0,
- argonBlake2bArbitraryLenghtHash(
- (h0 + 0.toUInt().toLittleEndianUByteArray() + i.toUInt().toLittleEndianUByteArray()).toUByteArray(),
- 1024U
- )
- )
- }
-
- //Compute B[i][1]
- for (i in 0 until parallelism) {
- matrix.setBlockAt(i, 1,
- argonBlake2bArbitraryLenghtHash(
- (h0 + 1.toUInt().toLittleEndianUByteArray() + i.toUInt().toLittleEndianUByteArray()).toUByteArray(),
- 1024U
- )
- )
- }
- //Run all iterations over all lanes and all segments
- executeArgonWithSingleThread()
-
-
- val acc = ArgonBlock(matrix.getBlockAt(0, columnCount - 1))
- val accPointer = acc.getBlockPointer()
- for (i in 1 until parallelism) {
- accPointer.xorInplaceWith(matrix.getBlockPointer(i, columnCount - 1))
- }
- //Hash the xored last blocks
- val hash = argonBlake2bArbitraryLenghtHash(acc.storage, tagLength)
- matrix.clearMatrix()
- return hash
-
-
- }
-
- private fun executeArgonWithSingleThread() {
- for (iteration in 0 until numberOfIterations) {
- for (slice in 0 until 4) {
- for (lane in 0 until parallelism) {
- val segmentPosition = SegmentPosition(iteration, lane, slice)
- processSegment(segmentPosition)
- }
- }
- }
- }
-
- private fun processSegment(segmentPosition: SegmentPosition) {
- val iteration = segmentPosition.iteration
- val slice = segmentPosition.slice
- val lane = segmentPosition.lane
-
- var addressBlock: ArgonBlockPointer? = null
- var addressCounter = 1UL //Starts from 1 in each segment as defined by the spec
-
- //Generate initial segment address block
- if (useIndependentAddressing) {
- addressBlock = ArgonBlock().getBlockPointer()
- addressBlock = populateAddressBlock(iteration, slice, lane, addressBlock, addressCounter)
- addressCounter++
- }
- val startColumn = if (iteration == 0 && slice == 0) {
- 2
- } else {
- slice * segmentLength
- }
-
-
- for (column in startColumn until (slice + 1) * segmentLength) {
- val segmentIndex = column - (slice * segmentLength)
- //Each address block contains 128 addresses, and we use one per iteration,
- //so once we do 128 iterations we need to calculate a new address block
- if (useIndependentAddressing && segmentIndex != 0 && segmentIndex % 128 == 0) {
- addressBlock = populateAddressBlock(iteration, slice, lane, addressBlock!!, addressCounter)
- addressCounter++
- }
- val previousColumn = if (column == 0) {
- columnCount - 1
- } else {
- column - 1
- }
- val (l, z) = computeReferenceBlockIndexes(
- iteration,
- slice,
- lane,
- column,
- addressBlock
- )
-
- matrix.setBlockAt(lane, column,
- compressionFunctionG(
- matrix.getBlockPointer(lane, previousColumn),
- matrix.getBlockPointer(l,z),
- matrix.getBlockPointer(lane,column),
- true
- ).getAsUByteArray()
- )
- }
-
- }
-
-
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Utils.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Utils.kt
deleted file mode 100644
index 9647d7f..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/Argon2Utils.kt
+++ /dev/null
@@ -1,167 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_API_USAGE", "EXPERIMENTAL_UNSIGNED_LITERALS")
-
-package com.ionspin.kotlin.crypto.keyderivation.argon2
-
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bPure
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Utils.BLOCK_SIZE
-import com.ionspin.kotlin.crypto.util.plus
-import com.ionspin.kotlin.crypto.util.rotateRight
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-May-2020
- */
-object Argon2Utils {
- const val BLOCK_SIZE = 1024
-
- const val R1 = 32
- const val R2 = 24
- const val R3 = 16
- const val R4 = 63
-
- //Based on Blake2b mix
- internal fun inplaceMixRound(v : ULongArray) : ULongArray{
- mix(v, 0, 4, 8, 12)
- mix(v, 1, 5, 9, 13)
- mix(v, 2, 6, 10, 14)
- mix(v, 3, 7, 11, 15)
- mix(v, 0, 5, 10, 15)
- mix(v, 1, 6, 11, 12)
- mix(v, 2, 7, 8, 13)
- mix(v, 3, 4, 9, 14)
- return v //Just for chaining, array is mixed in place
- }
-
- //Based on Blake2b mix
- private fun mix(v: ULongArray, a: Int, b: Int, c: Int, d: Int) {
- v[a] = (v[a] + v[b] + 2U * (v[a] and 0xFFFFFFFFUL) * (v[b] and 0xFFFFFFFFUL))
- v[d] = (v[d] xor v[a]) rotateRight R1
- v[c] = (v[c] + v[d] + 2U * (v[c] and 0xFFFFFFFFUL) * (v[d] and 0xFFFFFFFFUL))
- v[b] = (v[b] xor v[c]) rotateRight R2
- v[a] = (v[a] + v[b] + 2U * (v[a] and 0xFFFFFFFFUL) * (v[b] and 0xFFFFFFFFUL))
- v[d] = (v[d] xor v[a]) rotateRight R3
- v[c] = (v[c] + v[d] + 2U * (v[c] and 0xFFFFFFFFUL) * (v[d] and 0xFFFFFFFFUL))
- v[b] = (v[b] xor v[c]) rotateRight R4
- }
-
- internal fun extractColumnFromGBlock(gBlock: UByteArray, columnPosition: Int): UByteArray {
- val result = UByteArray(128) { 0U }
- for (i in 0..7) {
- gBlock.copyOfRange(i * 128 + (columnPosition * 16), i * 128 + (columnPosition * 16) + 16)
- .copyInto(result, i * 16)
- }
- return result
- }
-
-
-
- internal fun compressionFunctionG(
- previousBlock: ArgonBlockPointer,
- referenceBlock: ArgonBlockPointer,
- currentBlock: ArgonBlockPointer,
- xorWithCurrentBlock: Boolean
- ): ArgonBlockPointer {
- val r = (referenceBlock xorBlocksAndGetPointerToNewBlock previousBlock).getBlockPointer()
- //Since we are doing inplace xors, we don't need the Q that exists in specification
- val z = ArgonBlock().getBlockPointer()
- // Do the argon/blake2b mixing on rows
- for (i in 0..7) {
- z.setRowFromMixedULongs(i, inplaceMixRound(r.getRowOfULongsForMixing(i)))
- }
- // Do the argon/blake2b mixing on columns
- for (i in 0..7) {
- z.setColumnFromMixedULongs(i, inplaceMixRound(z.getColumnOfULongsForMixing(i)))
- }
- val final = if (xorWithCurrentBlock) {
- (z xorInplaceWith r) xorInplaceWith currentBlock
- } else {
- z xorInplaceWith r
- }
- return final
- }
-
- internal fun argonBlake2bArbitraryLenghtHash(input: UByteArray, length: UInt): UByteArray {
- if (length <= 64U) {
- return Blake2bPure.digest(inputMessage = length + input, hashLength = length.toInt())
- }
- //We can cast to int because UInt even if MAX_VALUE divided by 32 is guaranteed not to overflow
- val numberOf64ByteBlocks = (1U + ((length - 1U) / 32U) - 2U).toInt() // equivalent to ceil(length/32) - 2
- val v = Array(numberOf64ByteBlocks) { ubyteArrayOf() }
- v[0] = Blake2bPure.digest(length + input)
- for (i in 1 until numberOf64ByteBlocks) {
- v[i] = Blake2bPure.digest(v[i - 1])
- }
- val remainingPartOfInput = length.toInt() - numberOf64ByteBlocks * 32
- val vLast = Blake2bPure.digest(v[numberOf64ByteBlocks - 1], hashLength = remainingPartOfInput)
- val concat =
- (v.map { it.copyOfRange(0, 32) })
- .plus(listOf(vLast))
- .foldRight(ubyteArrayOf()) { arrayOfUBytes, acc -> arrayOfUBytes + acc }
-
- return concat
- }
-
- /**
- * Validates the argon 2 parameters.
- * Since Kotlin arrays that we are currently using cannot have more than 2^31 bytes, we don't need to check
- * sizes for password, salt, key and associated data. Also since UInt is 32bit we cant set more than 2^32-1 of
- * tagLength, requested memory size and number of iterations, so no need to check for upper bound, just lower.
- */
- internal fun validateArgonParameters(
- password: UByteArray,
- salt: UByteArray,
- parallelism: Int ,
- tagLength: UInt,
- requestedMemorySize: UInt ,
- numberOfIterations: Int ,
- key: UByteArray,
- associatedData: UByteArray,
- argonType: ArgonType
- ) {
-
- //Parallelism
- if (parallelism > 0xFFFFFF) {
- throw Argon2LanesTooMany(parallelism)
- }
- if (parallelism <= 0) {
- throw Argon2LanesTooFew(parallelism)
- }
- //Tag length
- if (tagLength <= 0U) {
- throw Argon2TagTooShort(tagLength)
- }
- //Requested memory
- if (requestedMemorySize < 8U || requestedMemorySize < (8 * parallelism).toUInt()) {
- throw Argon2MemoryTooLitlle(requestedMemorySize)
- }
- //Number of iterations
- if (numberOfIterations <= 0) {
- throw Argon2TimeTooShort(numberOfIterations)
- }
-
- }
-}
-
-// ------------ Arithmetic and other utils
-
-
-fun UByteArray.xorWithBlock(other : ArgonMatrix, rowPosition: Int, columnPosition: Int) : UByteArray {
- return UByteArray(BLOCK_SIZE) { this[it] xor other[rowPosition, columnPosition, it] }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/ArgonMatrix.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/ArgonMatrix.kt
deleted file mode 100644
index 904c048..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/keyderivation/argon2/ArgonMatrix.kt
+++ /dev/null
@@ -1,285 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_API_USAGE", "EXPERIMENTAL_UNSIGNED_LITERALS")
-
-package com.ionspin.kotlin.crypto.keyderivation.argon2
-
-import com.ionspin.kotlin.crypto.util.xor
-
-/**
- * Represents a pointer to a Argon2 Block, this abstracts what the backing structure is, a Argon 2 Matrix or
- * or a UByteArray block
- */
-interface ArgonBlockPointer {
- companion object {
- private val _emitLongArray : LongArray = longArrayOf(1L,2L)
- }
- val blockStartPosition: Int
-
- fun pointerArithmetic(block : (Int, Int) -> Int) : ArgonBlockPointer
-
- infix fun xorBlocksAndGetPointerToNewBlock(other: ArgonBlockPointer) : ArgonBlock
-
- operator fun get(blockPosition: Int) : UByte
-
- operator fun set(blockPosition: Int, value: UByte)
-
- infix fun xorInplaceWith(other: ArgonBlockPointer) : ArgonBlockPointer {
- for (it in 0 until 1024) {
- this[it] = this[it] xor other[it]
- }
- return this //For chaining
- }
-
- fun asInt() : Int
-
- fun getAsUByteArray() : UByteArray
-}
-
-fun ArgonBlockPointer._emitLongArray() : LongArray = longArrayOf(0,1)
-
-fun ArgonBlockPointer.getRowOfULongsForMixing(rowIndex: Int) : ULongArray {
- // Each row has 16 unsigned longs (16 ulongs * 8 bytes = 128 bytes) -- Argon2 considers this as 2 word unsigned
- // numbers, so strictly speaking argon representation is 8 * 8 matrix of 2 word unsigned numbers (registers
- val ulongArray = ULongArray(16)
- for (columnIndex in 0 until 16) {
- var ulong = 0UL
- //Now we create the ulong
- for (bytePosition in 0 until 8) {
- ulong = ulong or (this[rowIndex * 128 + columnIndex * 8 + bytePosition].toULong() shl (bytePosition * 8))
- }
- ulongArray[columnIndex] = ulong
- }
- return ulongArray
-}
-
-fun ArgonBlockPointer.setRowFromMixedULongs(rowIndex: Int, ulongs: ULongArray) {
- // Each row has 16 unsigned longs (16 ulongs * 8 bytes = 128 bytes) -- Argon2 considers this as 2 word unsigned
- // numbers, so strictly speaking argon representation is 8 * 8 matrix of 2 word unsigned numbers (registers
- for (columnIndex in 0 until 16) {
- val ulongToConvert = ulongs[columnIndex]
- for (bytePosition in 0 until 8) {
- this[rowIndex * 128 + columnIndex * 8 + bytePosition] = ((ulongToConvert shr (bytePosition * 8)) and 0xFFU).toUByte()
- }
- }
-}
-
-fun ArgonBlockPointer.getColumnOfULongsForMixing(columnIndex: Int) : ULongArray {
- //In Argon2 representation there are 8 double word registers (numbers, but we work with 16 single word ulongs
- val ulongArray = ULongArray(16)
- //There are 8 rows that consist of 2 words (registers, in our case ulongs) each
- for (rowIndex in 0 until 8) {
- var ulong = 0UL
- //Now we create the ulong
- for (bytePosition in 0 until 8) {
- ulong = ulong or (this[rowIndex * 128 + columnIndex * 16 + bytePosition].toULong() shl (bytePosition * 8))
- }
- ulongArray[rowIndex * 2] = ulong
- ulong = 0UL
- // But unlike in columns where we can directly iterate and get all TWO WORD registers, here we also need to grab
- // the next word
- for (bytePosition in 8 until 16) {
- ulong = ulong or (this[rowIndex * 128 + columnIndex * 16 + bytePosition].toULong() shl (bytePosition * 8))
- }
- ulongArray[rowIndex * 2 + 1] = ulong
- }
- return ulongArray
-}
-
-fun ArgonBlockPointer.setColumnFromMixedULongs(columnIndex: Int, ulongs: ULongArray) {
- //In Argon2 representation there are 8 double word registers (numbers, but we work with 16 single word ulongs
- //There are 8 rows that consist of 2 words (registers, in our case ulongs) each
- var ulongToConvert = 0UL
- for (rowIndex in 0 until 8) {
- ulongToConvert = ulongs[rowIndex * 2]
- //Now we create the ulong
- for (bytePosition in 0 until 8) {
- this[rowIndex * 128 + columnIndex * 16 + bytePosition] = ((ulongToConvert shr (bytePosition * 8)) and 0xFFU).toUByte()
- }
- // But unlike in columns where we can directly iterate and get all TWO WORD registers, here we also need to set
- // the next word
- ulongToConvert = ulongs[rowIndex * 2 + 1]
- for (bytePosition in 8 until 16) {
- this[rowIndex * 128 + columnIndex * 16 + bytePosition] = ((ulongToConvert shr (bytePosition * 8)) and 0xFFU).toUByte()
- }
- }
-}
-
-fun ArgonBlockPointer.getUIntFromPosition(positionInBlock: Int) : UInt {
- var uint = 0U
- for (i in 0 until 4) {
- uint = uint or (this[positionInBlock + i].toUInt() shl (i * 8))
- }
- return uint
-}
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-May-2020
- */
- class ArgonMatrix(val columnCount: Int, val rowCount: Int) {
-
- internal val storage: UByteArray = UByteArray(columnCount * rowCount * 1024)
-
- operator fun get(rowPosition: Int, columnPosition: Int, inBlockPosition: Int) : UByte {
- if (rowPosition > rowCount - 1) {
- throw RuntimeException("Invalid row (lane) requested: $rowPosition, rowCount: $rowCount")
- }
- if (columnPosition > columnCount - 1) {
- throw RuntimeException("Invalid column requested: $columnPosition, columnCount: $columnCount")
- }
- return storage[getBlockStartPositionPointer(rowPosition, columnPosition) + inBlockPosition]
- }
-
- val size = storage.size
-
- operator fun get(absolutePosition: Int) : UByte {
- return storage[absolutePosition]
- }
-
- operator fun set(rowPosition: Int, columnPosition: Int, inBlockPosition: Int, value: UByte) {
- storage[getBlockStartPositionPointer(rowPosition, columnPosition) + inBlockPosition] = value
- }
-
- operator fun set(absolutePosition: Int, value: UByte) {
- storage[absolutePosition] = value
- }
-
- fun getBlockPointer(rowPosition: Int, columnPosition: Int) : ArgonBlockPointer {
- return ArgonBlockPointerWithMatrix(getBlockStartPositionPointer(rowPosition, columnPosition), this)
- }
-
-
- fun sliceArray(indices: IntRange): UByteArray {
- return storage.sliceArray(indices)
- }
-
- fun getBlockAt(rowPosition: Int, columnPosition: Int) : UByteArray {
- println("Expensive get")
- return storage.copyOfRange(
- getBlockStartPositionPointer(rowPosition, columnPosition),
- getBlockStartPositionPointer(rowPosition, columnPosition) + 1024
- )
- }
-
- fun setBlockAt(rowPosition: Int, columnPosition: Int, blockValue: UByteArray) {
- blockValue.copyInto(
- storage,
- getBlockStartPositionPointer(rowPosition, columnPosition)
- )
- }
-
- private inline fun getBlockStartPositionPointer(rowPosition: Int, columnPosition: Int) : Int {
- return rowPosition * columnCount * 1024 + columnPosition * 1024
- }
-
- internal fun clearMatrix() {
- for( index in storage.indices) { storage[index] = 0U }
- }
-
- private class ArgonBlockPointerWithMatrix constructor(override val blockStartPosition: Int, val matrix: ArgonMatrix) : ArgonBlockPointer {
-
- override fun pointerArithmetic(block: (Int, Int) -> Int): ArgonBlockPointer {
- return ArgonBlockPointerWithMatrix(block(blockStartPosition, matrix.size), matrix)
- }
-
- override fun asInt(): Int {
- return blockStartPosition
- }
-
- override operator fun get(blockPosition: Int) : UByte {
- return matrix[blockStartPosition + blockPosition]
- }
-
- override fun set(blockPosition: Int, value: UByte) {
- matrix[blockStartPosition + blockPosition] = value
- }
-
- override infix fun xorBlocksAndGetPointerToNewBlock(other: ArgonBlockPointer) : ArgonBlock {
- return ArgonBlock(UByteArray(1024){
- matrix[blockStartPosition + it] xor other[it]
- })
- }
-
- override fun getAsUByteArray(): UByteArray {
- return matrix.storage.slice(blockStartPosition until blockStartPosition + 1024).toUByteArray()
- }
- }
-}
-
-
-
-
-@Suppress("NON_PUBLIC_PRIMARY_CONSTRUCTOR_OF_INLINE_CLASS")
-inline class ArgonBlock internal constructor(internal val storage: UByteArray) {
- constructor() : this(UByteArray(1024))
- operator fun get(index: Int) : UByte {
- return storage.get(index)
- }
- operator fun set(index: Int, value: UByte) {
- storage.set(index, value)
- }
-
- val size: Int get() = storage.size
-
- internal fun getAsUByteArray() : UByteArray = storage
-
- fun getBlockPointer() : ArgonBlockPointer{
- return ArgonBlockPointerWithBlock( this)
- }
-
- infix fun xorInplaceWith(other: ArgonBlock) : ArgonBlock {
- storage.indices.forEach {
- this[it] = this[it] xor other[it]
- }
- return this //For chaining
- }
-
-
-
- private class ArgonBlockPointerWithBlock constructor(val storageBlock: ArgonBlock) : ArgonBlockPointer {
- override val blockStartPosition: Int = 0
-
- override fun pointerArithmetic(block: (Int, Int) -> Int): ArgonBlockPointer {
- throw RuntimeException("Haven't really tought out pointer arithmetic with blocks")
- }
-
- override fun asInt(): Int {
- return blockStartPosition
- }
- override operator fun get(blockPosition: Int) : UByte {
- return storageBlock[blockPosition]
- }
-
- override fun set(blockPosition: Int, value: UByte) {
- storageBlock[blockPosition] = value
- }
-
- override infix fun xorBlocksAndGetPointerToNewBlock(other: ArgonBlockPointer) : ArgonBlock {
- return ArgonBlock(UByteArray(1024){
- storageBlock[it] xor other[it]
- })
- }
-
- override fun getAsUByteArray(): UByteArray {
- return storageBlock.storage
- }
-
- }
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/mac/Poly1305.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/mac/Poly1305.kt
deleted file mode 100644
index 406ebeb..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/mac/Poly1305.kt
+++ /dev/null
@@ -1,118 +0,0 @@
-package com.ionspin.kotlin.crypto.mac
-
-import com.ionspin.kotlin.bignum.Endianness
-import com.ionspin.kotlin.bignum.integer.BigInteger
-import com.ionspin.kotlin.bignum.integer.Sign
-import com.ionspin.kotlin.crypto.util.fromLittleEndianUByteArrayToBigEndianUByteArray
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 18-Jun-2020
- */
-class Poly1305(key: UByteArray) {
- companion object {
- fun clampR(r: UByteArray) : UByteArray {
- val clamped = UByteArray(16) { r[it] }
- clamped[3] = r[3] and 0b00001111U
- clamped[7] = r[7] and 0b00001111U
- clamped[11] = r[11] and 0b00001111U
- clamped[15] = r[15] and 0b00001111U
-
- clamped[4] = r[4] and 0b11111100U
- clamped[8] = r[8] and 0b11111100U
- clamped[12] = r[12] and 0b11111100U
- return clamped
-
- }
-
- val P = BigInteger.fromUByteArray(
- ubyteArrayOf(
- 0x03U, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xffU, 0xfbU
- ),
- Sign.POSITIVE
- )
- val powersOfTwo = Array(129) {
- BigInteger.ONE shl it
- }
- val resultMask = (BigInteger.ONE shl 128) - 1
- //Doesn't have to be every power, just divisible by 8
- val twoToThe128 = BigInteger.ONE.shl(128)
-
- /**
- * Limit - stop poly calculating tag at desired index, ignored if 0
- */
- fun poly1305Authenticate(key: UByteArray, message: UByteArray) : UByteArray {
- val r = clampR(UByteArray(16) { key[it] })
- val s= UByteArray(16) { key[it + 16]}
-
- var accumulator = BigInteger.ZERO
- val rAsBigInt = BigInteger.fromUByteArray(r.fromLittleEndianUByteArrayToBigEndianUByteArray(), Sign.POSITIVE) //TODO convert from little endian ubyte array to what BigInteger expects
- val sAsBigInt = BigInteger.fromUByteArray(s.fromLittleEndianUByteArrayToBigEndianUByteArray(), Sign.POSITIVE)
- val blocks = message.size / 16
- val remainder = message.size % 16
-
- for (i in 0 until blocks) {
- val slice = message.sliceArray(i * 16 until i * 16 + 16)
- slice.hexColumsPrint()
- val blockAsInt = BigInteger.fromUByteArray(slice.fromLittleEndianUByteArrayToBigEndianUByteArray(), Sign.POSITIVE) + powersOfTwo[128]
- accumulator += blockAsInt
- accumulator *= rAsBigInt
- accumulator %= P
- }
- if (remainder != 0) {
- val slice = message.sliceArray(blocks * 16 until blocks * 16 + remainder)
- val blockAsInt = BigInteger.fromUByteArray(slice.fromLittleEndianUByteArrayToBigEndianUByteArray(), Sign.POSITIVE) + powersOfTwo[remainder * 8]
- accumulator += blockAsInt
- accumulator *= rAsBigInt
- accumulator %= P
- }
-
- accumulator += sAsBigInt
- accumulator = accumulator and resultMask
- val result = accumulator.toUByteArray()
- result.reverse()
- return result
-
-
- }
- }
- var rAsBigInt = BigInteger.fromUByteArray(
- clampR(key.sliceArray(0 until 16)).fromLittleEndianUByteArrayToBigEndianUByteArray(),
- Sign.POSITIVE
- )
- var sAsBigInt = BigInteger.fromUByteArray(
- key.sliceArray(16 until 32).fromLittleEndianUByteArrayToBigEndianUByteArray(),
- Sign.POSITIVE)
- var accumulator = BigInteger.ZERO
-
- fun updateMac(data : UByteArray) {
- if (data.size != 16) {
- throw RuntimeException("Invalide block size, required 16, got ${data.size}")
- }
- val blockAsInt = BigInteger.fromUByteArray(
- data.fromLittleEndianUByteArrayToBigEndianUByteArray(), Sign.POSITIVE
- ) + powersOfTwo[128]
- accumulator += blockAsInt
- accumulator *= rAsBigInt
- accumulator %= P
- }
-
- fun finalizeMac(data: UByteArray = ubyteArrayOf()) : UByteArray{
- if (data.size != 0) {
- val blockAsInt = BigInteger.fromUByteArray(
- data.fromLittleEndianUByteArrayToBigEndianUByteArray(),
- Sign.POSITIVE
- ) + powersOfTwo[data.size * 8]
- accumulator += blockAsInt
- accumulator *= rAsBigInt
- accumulator %= P
- }
- accumulator += sAsBigInt
- accumulator = accumulator and resultMask
- val result = accumulator.toUByteArray()
- result.reverse()
- return result
- }
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/Aes.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/Aes.kt
deleted file mode 100644
index 55ceeb7..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/Aes.kt
+++ /dev/null
@@ -1,28 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 13-Jun-2020
- */
-internal sealed class InternalAesKey(val key: String, val keyLength: Int) {
- val keyArray: UByteArray = key.hexStringToUByteArray()
- val numberOf32BitWords = keyLength / 32
-
- class Aes128Key(key: String) : InternalAesKey(key, 128)
- class Aes192Key(key: String) : InternalAesKey(key, 192)
- class Aes256Key(key: String) : InternalAesKey(key, 256)
-
- init {
- checkKeyLength(key, keyLength)
- }
-
- fun checkKeyLength(key: String, expectedLength: Int) {
- if ((key.length / 2) != expectedLength / 8) {
- throw RuntimeException("Invalid key length")
- }
- }
-}
-
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCbcPure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCbcPure.kt
deleted file mode 100644
index ae9acbd..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCbcPure.kt
+++ /dev/null
@@ -1,243 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.SRNG
-import com.ionspin.kotlin.crypto.util.xor
-
-/**
- * Advanced encryption standard with cipher block chaining and PKCS #5
- *
- * For bulk encryption/decryption use [AesCbcPure.encrypt] and [AesCbcPure.decrypt]
- *
- * To get an instance of AesCbc and then feed it data sequentially with [addData] use [createEncryptor] and [createDecryptor]
- *
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-
-internal class AesCbcPure internal constructor(val aesKey: InternalAesKey, val mode: Mode, initializationVector: UByteArray? = null) {
-
- companion object {
- const val BLOCK_BYTES = 16
- /**
- * Creates and returns AesCbc instance that can be fed data using [addData]. Once you have submitted all
- * data call [encrypt]
- */
- fun createEncryptor(aesKey: InternalAesKey) : AesCbcPure {
- return AesCbcPure(aesKey, Mode.ENCRYPT)
- }
- /**
- * Creates and returns AesCbc instance that can be fed data using [addData]. Once you have submitted all
- * data call [decrypt]
- */
- fun createDecryptor(aesKey : InternalAesKey) : AesCbcPure {
- return AesCbcPure(aesKey, Mode.DECRYPT)
- }
-
- /**
- * Bulk encryption, returns encrypted data and a random initialization vector
- */
- fun encrypt(aesKey: InternalAesKey, data: UByteArray): EncryptedDataAndInitializationVector {
- val aesCbc = AesCbcPure(aesKey, Mode.ENCRYPT)
- aesCbc.addData(data)
- return aesCbc.encrypt()
- }
-
- /**
- * Bulk decryption, returns decrypted data
- */
- fun decrypt(aesKey: InternalAesKey, data: UByteArray, initialCounter: UByteArray? = null): UByteArray {
- val aesCbc = AesCbcPure(aesKey, Mode.DECRYPT, initialCounter)
- aesCbc.addData(data)
- return aesCbc.decrypt()
- }
-
- private fun padToBlock(unpadded: UByteArray): UByteArray {
- val paddingSize = 16 - unpadded.size
- if (unpadded.size == BLOCK_BYTES) {
- return unpadded
- }
-
- if (unpadded.size == BLOCK_BYTES) {
- return UByteArray(BLOCK_BYTES) {
- BLOCK_BYTES.toUByte()
- }
- }
-
- if (unpadded.size > BLOCK_BYTES) {
- throw IllegalStateException("Block larger than 128 bytes")
- }
-
- return UByteArray(BLOCK_BYTES) {
- when (it) {
- in unpadded.indices -> unpadded[it]
- else -> paddingSize.toUByte()
- }
- }
-
- }
- }
-
- var currentOutput: UByteArray = ubyteArrayOf()
- var previousEncrypted: UByteArray = ubyteArrayOf()
- val initVector = if (initializationVector.isNullOrEmpty()) {
- SRNG.getRandomBytes(16)
- } else {
- initializationVector
- }
-
- val output = MutableList(0) { ubyteArrayOf() }
-
- var buffer: UByteArray = UByteArray(16) { 0U }
- var bufferCounter = 0
-
- fun addData(data: UByteArray) {
- //Padding
- when {
- bufferCounter + data.size < BLOCK_BYTES -> appendToBuffer(data, bufferCounter)
- bufferCounter + data.size >= BLOCK_BYTES -> {
- val chunked = data.chunked(BLOCK_BYTES)
- chunked.forEach { chunk ->
- if (bufferCounter + chunk.size < BLOCK_BYTES) {
- appendToBuffer(chunk.toUByteArray(), bufferCounter)
- } else {
- chunk.toUByteArray().copyInto(
- destination = buffer,
- destinationOffset = bufferCounter,
- startIndex = 0,
- endIndex = BLOCK_BYTES - bufferCounter
- )
- output += consumeBlock(buffer)
- buffer = UByteArray(BLOCK_BYTES) {
- when (it) {
- in (0 until (chunk.size - (BLOCK_BYTES - bufferCounter))) -> {
- chunk[it + (BLOCK_BYTES - bufferCounter)]
- }
- else -> {
- 0U
- }
- }
-
- }
- bufferCounter = chunk.size - (BLOCK_BYTES - bufferCounter)
- }
- }
-
- }
- }
-
- }
-
- /**
- * Encrypt fed data and return it alongside the randomly chosen initialization vector.
- * This also applies correct PKCS#7 padding
- * @return Encrypted data and initialization vector
- */
- fun encrypt(): EncryptedDataAndInitializationVector {
- if (bufferCounter > 0) {
- val lastBlockPadded = padToBlock(buffer)
- if (lastBlockPadded.size > BLOCK_BYTES) {
- val chunks = lastBlockPadded.chunked(BLOCK_BYTES).map { it.toUByteArray() }
- output += consumeBlock(chunks[0])
- output += consumeBlock(chunks[1])
- } else {
- output += consumeBlock(lastBlockPadded)
- }
- } else {
- output += consumeBlock(UByteArray(BLOCK_BYTES) { BLOCK_BYTES.toUByte()})
- }
- return EncryptedDataAndInitializationVector(
- output.reversed().foldRight(UByteArray(0) { 0U }) { arrayOfUBytes, acc -> acc + arrayOfUBytes },
- initVector
- )
- }
-
- /**
- * Decrypt data
- * @return Decrypted data
- */
- fun decrypt(): UByteArray {
- val removePaddingCount = output.last().last()
-
- val removedPadding = if (removePaddingCount > 0U && removePaddingCount < 16U) {
- output.last().dropLast(removePaddingCount.toInt() and 0x7F)
- } else {
- ubyteArrayOf()
- }.toUByteArray()
- val preparedOutput = (output.dropLast(1) + listOf(removedPadding))
- //JS compiler freaks out here if we don't supply exact type
- val reversed : List = preparedOutput.reversed() as List
- val folded : UByteArray = reversed.foldRight(UByteArray(0) { 0U }) { uByteArray, acc ->
- acc + uByteArray
- }
- return folded
-
- }
-
- private fun appendToBuffer(array: UByteArray, start: Int) {
- array.copyInto(destination = buffer, destinationOffset = start, startIndex = 0, endIndex = array.size)
- bufferCounter += array.size
- }
-
- private fun consumeBlock(data: UByteArray): UByteArray {
- return when (mode) {
- Mode.ENCRYPT -> {
- currentOutput = if (currentOutput.isEmpty()) {
- println("IV: $initVector")
- AesPure.encrypt(aesKey, data xor initVector)
- } else {
- AesPure.encrypt(aesKey, data xor currentOutput)
- }
- currentOutput
- }
- Mode.DECRYPT -> {
- if (currentOutput.isEmpty()) {
- currentOutput = AesPure.decrypt(aesKey, data) xor initVector
- } else {
- currentOutput = AesPure.decrypt(aesKey, data) xor previousEncrypted
- }
- previousEncrypted = data
- currentOutput
- }
- }
-
- }
-
-}
-
-
-data class EncryptedDataAndInitializationVector(val encryptedData : UByteArray, val initializationVector : UByteArray) {
- override fun equals(other: Any?): Boolean {
- if (this === other) return true
- if (other == null || this::class != other::class) return false
-
- other as EncryptedDataAndInitializationVector
-
- if (!encryptedData.contentEquals(other.encryptedData)) return false
- if (!initializationVector.contentEquals(other.initializationVector)) return false
-
- return true
- }
-
- override fun hashCode(): Int {
- var result = encryptedData.contentHashCode()
- result = 31 * result + initializationVector.contentHashCode()
- return result
- }
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCtrPure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCtrPure.kt
deleted file mode 100644
index 6b62b14..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCtrPure.kt
+++ /dev/null
@@ -1,209 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.bignum.Endianness
-import com.ionspin.kotlin.bignum.integer.BigInteger
-import com.ionspin.kotlin.bignum.integer.Sign
-import com.ionspin.kotlin.bignum.modular.ModularBigInteger
-import com.ionspin.kotlin.crypto.SRNG
-import com.ionspin.kotlin.crypto.symmetric.AesCtrPure.Companion.encrypt
-import com.ionspin.kotlin.crypto.util.xor
-
-/**
- *
- * Advanced encryption standard with counter mode
- *
- * For bulk encryption/decryption use [AesCtrPure.encrypt] and [AesCtrPure.decrypt]
- *
- * To get an instance of AesCtr and then feed it data sequentially with [addData] use [createEncryptor] and [createDecryptor]
- *
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 22-Sep-2019
- */
-
-internal class AesCtrPure internal constructor(val aesKey: InternalAesKey, val mode: Mode, initialCounter: UByteArray? = null) {
-
- companion object {
- const val BLOCK_BYTES = 16
-
- val modularCreator = ModularBigInteger.creatorForModulo(BigInteger.ONE.shl(128) - 1)
- /**
- * Creates and returns AesCtr instance that can be fed data using [addData]. Once you have submitted all
- * data call [encrypt]
- */
- fun createEncryptor(aesKey: InternalAesKey) : AesCtrPure {
- return AesCtrPure(aesKey, Mode.ENCRYPT)
- }
- /**
- * Creates and returns AesCtr instance that can be fed data using [addData]. Once you have submitted all
- * data call [decrypt]
- */
- fun createDecryptor(aesKey : InternalAesKey, initialCounter: UByteArray) : AesCtrPure {
- return AesCtrPure(aesKey, Mode.DECRYPT, initialCounter)
- }
- /**
- * Bulk encryption, returns encrypted data and a random initial counter
- */
- fun encrypt(aesKey: InternalAesKey, data: UByteArray): EncryptedDataAndInitialCounter {
- val aesCtr = AesCtrPure(aesKey, Mode.ENCRYPT)
- aesCtr.addData(data)
- return aesCtr.encrypt()
- }
- /**
- * Bulk decryption, returns decrypted data
- */
- fun decrypt(aesKey: InternalAesKey, data: UByteArray, initialCounter: UByteArray? = null): UByteArray {
- val aesCtr = AesCtrPure(aesKey = aesKey, mode = Mode.DECRYPT, initialCounter = initialCounter)
- aesCtr.addData(data)
- return aesCtr.decrypt()
- }
-
- }
-
- var currentOutput: UByteArray = ubyteArrayOf()
- var previousEncrypted: UByteArray = ubyteArrayOf()
- val counterStart = if (initialCounter.isNullOrEmpty()) {
- SRNG.getRandomBytes(16)
- } else {
- initialCounter
- }
- var blockCounter = modularCreator.fromBigInteger(BigInteger.fromUByteArray(counterStart, Sign.POSITIVE))
-
- val output = MutableList(0) { ubyteArrayOf() }
-
- var buffer: UByteArray = UByteArray(16) { 0U }
- var bufferCounter = 0
-
- fun addData(data: UByteArray) {
- //Padding
- when {
- bufferCounter + data.size < BLOCK_BYTES -> appendToBuffer(data, bufferCounter)
- bufferCounter + data.size >= BLOCK_BYTES -> {
- val chunked = data.chunked(BLOCK_BYTES)
- chunked.forEach { chunk ->
- if (bufferCounter + chunk.size < BLOCK_BYTES) {
- appendToBuffer(chunk.toUByteArray(), bufferCounter)
- } else {
- chunk.toUByteArray().copyInto(
- destination = buffer,
- destinationOffset = bufferCounter,
- startIndex = 0,
- endIndex = BLOCK_BYTES - bufferCounter
- )
- output += consumeBlock(buffer, blockCounter)
- blockCounter += 1
- buffer = UByteArray(BLOCK_BYTES) {
- when (it) {
- in (0 until (chunk.size - (BLOCK_BYTES - bufferCounter))) -> {
- chunk[it + (BLOCK_BYTES - bufferCounter)]
- }
- else -> {
- 0U
- }
- }
-
- }
- bufferCounter = chunk.size - (BLOCK_BYTES - bufferCounter)
- }
- }
-
- }
- }
-
- }
- /**
- * Encrypt fed data and return it alongside the randomly chosen initial counter state
- * @return Encrypted data and initial counter state
- */
- fun encrypt(): EncryptedDataAndInitialCounter {
- if (bufferCounter > 0) {
- output += consumeBlock(buffer, blockCounter)
- }
- return EncryptedDataAndInitialCounter(
- output.reversed().foldRight(UByteArray(0) { 0U }) { arrayOfUBytes, acc -> acc + arrayOfUBytes },
- counterStart
- )
- }
- /**
- * Decrypt data
- * @return Decrypted data
- */
- fun decrypt(): UByteArray {
- if (bufferCounter > 0) {
- output += consumeBlock(buffer, blockCounter)
- }
- //JS compiler freaks out here if we don't supply exact type
- val reversed: List = output.reversed() as List
- val folded: UByteArray = reversed.foldRight(UByteArray(0) { 0U }) { arrayOfUBytes, acc ->
- acc + arrayOfUBytes
- }
- return folded
- }
-
- private fun appendToBuffer(array: UByteArray, start: Int) {
- array.copyInto(destination = buffer, destinationOffset = start, startIndex = 0, endIndex = array.size)
- bufferCounter += array.size
- }
-
- private fun consumeBlock(data: UByteArray, blockCount: ModularBigInteger): UByteArray {
- val blockCountAsByteArray = blockCount.toUByteArray().expandCounterTo16Bytes()
- return when (mode) {
- Mode.ENCRYPT -> {
- AesPure.encrypt(aesKey, blockCountAsByteArray) xor data
- }
- Mode.DECRYPT -> {
- AesPure.encrypt(aesKey, blockCountAsByteArray) xor data
- }
- }
-
- }
-
- private fun UByteArray.expandCounterTo16Bytes() : UByteArray {
- return if (this.size < 16) {
- println("Expanding")
- val diff = 16 - this.size
- val pad = UByteArray(diff) { 0U }
- pad + this
- } else {
- this
- }
- }
-
-}
-
-data class EncryptedDataAndInitialCounter(val encryptedData : UByteArray, val initialCounter : UByteArray) {
- override fun equals(other: Any?): Boolean {
- if (this === other) return true
- if (other == null || this::class != other::class) return false
-
- other as EncryptedDataAndInitialCounter
-
- if (!encryptedData.contentEquals(other.encryptedData)) return false
- if (!initialCounter.contentEquals(other.initialCounter)) return false
-
- return true
- }
-
- override fun hashCode(): Int {
- var result = encryptedData.contentHashCode()
- result = 31 * result + initialCounter.contentHashCode()
- return result
- }
-}
-
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesPure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesPure.kt
deleted file mode 100644
index d20b8e4..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/AesPure.kt
+++ /dev/null
@@ -1,361 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.util.flattenToUByteArray
-
-/**
- * Created by Ugljesa Jovanovic (jovanovic.ugljesa@gmail.com) on 07/Sep/2019
- */
-
-internal class AesPure internal constructor(val aesKey: InternalAesKey, val input: UByteArray) {
- companion object {
- private val debug = false
-
- private val sBox: UByteArray =
- ubyteArrayOf(
- // @formatter:off
- 0x63U, 0x7cU, 0x77U, 0x7bU, 0xf2U, 0x6bU, 0x6fU, 0xc5U, 0x30U, 0x01U, 0x67U, 0x2bU, 0xfeU, 0xd7U, 0xabU, 0x76U,
- 0xcaU, 0x82U, 0xc9U, 0x7dU, 0xfaU, 0x59U, 0x47U, 0xf0U, 0xadU, 0xd4U, 0xa2U, 0xafU, 0x9cU, 0xa4U, 0x72U, 0xc0U,
- 0xb7U, 0xfdU, 0x93U, 0x26U, 0x36U, 0x3fU, 0xf7U, 0xccU, 0x34U, 0xa5U, 0xe5U, 0xf1U, 0x71U, 0xd8U, 0x31U, 0x15U,
- 0x04U, 0xc7U, 0x23U, 0xc3U, 0x18U, 0x96U, 0x05U, 0x9aU, 0x07U, 0x12U, 0x80U, 0xe2U, 0xebU, 0x27U, 0xb2U, 0x75U,
- 0x09U, 0x83U, 0x2cU, 0x1aU, 0x1bU, 0x6eU, 0x5aU, 0xa0U, 0x52U, 0x3bU, 0xd6U, 0xb3U, 0x29U, 0xe3U, 0x2fU, 0x84U,
- 0x53U, 0xd1U, 0x00U, 0xedU, 0x20U, 0xfcU, 0xb1U, 0x5bU, 0x6aU, 0xcbU, 0xbeU, 0x39U, 0x4aU, 0x4cU, 0x58U, 0xcfU,
- 0xd0U, 0xefU, 0xaaU, 0xfbU, 0x43U, 0x4dU, 0x33U, 0x85U, 0x45U, 0xf9U, 0x02U, 0x7fU, 0x50U, 0x3cU, 0x9fU, 0xa8U,
- 0x51U, 0xa3U, 0x40U, 0x8fU, 0x92U, 0x9dU, 0x38U, 0xf5U, 0xbcU, 0xb6U, 0xdaU, 0x21U, 0x10U, 0xffU, 0xf3U, 0xd2U,
- 0xcdU, 0x0cU, 0x13U, 0xecU, 0x5fU, 0x97U, 0x44U, 0x17U, 0xc4U, 0xa7U, 0x7eU, 0x3dU, 0x64U, 0x5dU, 0x19U, 0x73U,
- 0x60U, 0x81U, 0x4fU, 0xdcU, 0x22U, 0x2aU, 0x90U, 0x88U, 0x46U, 0xeeU, 0xb8U, 0x14U, 0xdeU, 0x5eU, 0x0bU, 0xdbU,
- 0xe0U, 0x32U, 0x3aU, 0x0aU, 0x49U, 0x06U, 0x24U, 0x5cU, 0xc2U, 0xd3U, 0xacU, 0x62U, 0x91U, 0x95U, 0xe4U, 0x79U,
- 0xe7U, 0xc8U, 0x37U, 0x6dU, 0x8dU, 0xd5U, 0x4eU, 0xa9U, 0x6cU, 0x56U, 0xf4U, 0xeaU, 0x65U, 0x7aU, 0xaeU, 0x08U,
- 0xbaU, 0x78U, 0x25U, 0x2eU, 0x1cU, 0xa6U, 0xb4U, 0xc6U, 0xe8U, 0xddU, 0x74U, 0x1fU, 0x4bU, 0xbdU, 0x8bU, 0x8aU,
- 0x70U, 0x3eU, 0xb5U, 0x66U, 0x48U, 0x03U, 0xf6U, 0x0eU, 0x61U, 0x35U, 0x57U, 0xb9U, 0x86U, 0xc1U, 0x1dU, 0x9eU,
- 0xe1U, 0xf8U, 0x98U, 0x11U, 0x69U, 0xd9U, 0x8eU, 0x94U, 0x9bU, 0x1eU, 0x87U, 0xe9U, 0xceU, 0x55U, 0x28U, 0xdfU,
- 0x8cU, 0xa1U, 0x89U, 0x0dU, 0xbfU, 0xe6U, 0x42U, 0x68U, 0x41U, 0x99U, 0x2dU, 0x0fU, 0xb0U, 0x54U, 0xbbU, 0x16U
- // @formatter:on
- )
-
- private val inverseSBox: UByteArray =
- ubyteArrayOf(
- // @formatter:off
- 0x52U, 0x09U, 0x6aU, 0xd5U, 0x30U, 0x36U, 0xa5U, 0x38U, 0xbfU, 0x40U, 0xa3U, 0x9eU, 0x81U, 0xf3U, 0xd7U, 0xfbU,
- 0x7cU, 0xe3U, 0x39U, 0x82U, 0x9bU, 0x2fU, 0xffU, 0x87U, 0x34U, 0x8eU, 0x43U, 0x44U, 0xc4U, 0xdeU, 0xe9U, 0xcbU,
- 0x54U, 0x7bU, 0x94U, 0x32U, 0xa6U, 0xc2U, 0x23U, 0x3dU, 0xeeU, 0x4cU, 0x95U, 0x0bU, 0x42U, 0xfaU, 0xc3U, 0x4eU,
- 0x08U, 0x2eU, 0xa1U, 0x66U, 0x28U, 0xd9U, 0x24U, 0xb2U, 0x76U, 0x5bU, 0xa2U, 0x49U, 0x6dU, 0x8bU, 0xd1U, 0x25U,
- 0x72U, 0xf8U, 0xf6U, 0x64U, 0x86U, 0x68U, 0x98U, 0x16U, 0xd4U, 0xa4U, 0x5cU, 0xccU, 0x5dU, 0x65U, 0xb6U, 0x92U,
- 0x6cU, 0x70U, 0x48U, 0x50U, 0xfdU, 0xedU, 0xb9U, 0xdaU, 0x5eU, 0x15U, 0x46U, 0x57U, 0xa7U, 0x8dU, 0x9dU, 0x84U,
- 0x90U, 0xd8U, 0xabU, 0x00U, 0x8cU, 0xbcU, 0xd3U, 0x0aU, 0xf7U, 0xe4U, 0x58U, 0x05U, 0xb8U, 0xb3U, 0x45U, 0x06U,
- 0xd0U, 0x2cU, 0x1eU, 0x8fU, 0xcaU, 0x3fU, 0x0fU, 0x02U, 0xc1U, 0xafU, 0xbdU, 0x03U, 0x01U, 0x13U, 0x8aU, 0x6bU,
- 0x3aU, 0x91U, 0x11U, 0x41U, 0x4fU, 0x67U, 0xdcU, 0xeaU, 0x97U, 0xf2U, 0xcfU, 0xceU, 0xf0U, 0xb4U, 0xe6U, 0x73U,
- 0x96U, 0xacU, 0x74U, 0x22U, 0xe7U, 0xadU, 0x35U, 0x85U, 0xe2U, 0xf9U, 0x37U, 0xe8U, 0x1cU, 0x75U, 0xdfU, 0x6eU,
- 0x47U, 0xf1U, 0x1aU, 0x71U, 0x1dU, 0x29U, 0xc5U, 0x89U, 0x6fU, 0xb7U, 0x62U, 0x0eU, 0xaaU, 0x18U, 0xbeU, 0x1bU,
- 0xfcU, 0x56U, 0x3eU, 0x4bU, 0xc6U, 0xd2U, 0x79U, 0x20U, 0x9aU, 0xdbU, 0xc0U, 0xfeU, 0x78U, 0xcdU, 0x5aU, 0xf4U,
- 0x1fU, 0xddU, 0xa8U, 0x33U, 0x88U, 0x07U, 0xc7U, 0x31U, 0xb1U, 0x12U, 0x10U, 0x59U, 0x27U, 0x80U, 0xecU, 0x5fU,
- 0x60U, 0x51U, 0x7fU, 0xa9U, 0x19U, 0xb5U, 0x4aU, 0x0dU, 0x2dU, 0xe5U, 0x7aU, 0x9fU, 0x93U, 0xc9U, 0x9cU, 0xefU,
- 0xa0U, 0xe0U, 0x3bU, 0x4dU, 0xaeU, 0x2aU, 0xf5U, 0xb0U, 0xc8U, 0xebU, 0xbbU, 0x3cU, 0x83U, 0x53U, 0x99U, 0x61U,
- 0x17U, 0x2bU, 0x04U, 0x7eU, 0xbaU, 0x77U, 0xd6U, 0x26U, 0xe1U, 0x69U, 0x14U, 0x63U, 0x55U, 0x21U, 0x0cU, 0x7dU
- // @formatter:on
- )
-
- val rcon: UByteArray = ubyteArrayOf(0x8DU, 0x01U, 0x02U, 0x04U, 0x08U, 0x10U, 0x20U, 0x40U, 0x80U, 0x1BU, 0x36U)
-
- fun encrypt(aesKey: InternalAesKey, input: UByteArray): UByteArray {
- return AesPure(aesKey, input).encrypt()
- }
-
- fun decrypt(aesKey: InternalAesKey, input: UByteArray): UByteArray {
- return AesPure(aesKey, input).decrypt()
- }
-
- }
-
- val state: Array = (0 until 4).map { outerCounter ->
- UByteArray(4) { innerCounter -> input[innerCounter * 4 + outerCounter] }
- }.toTypedArray()
-
- val numberOfRounds = when (aesKey) {
- is InternalAesKey.Aes128Key -> 10
- is InternalAesKey.Aes192Key -> 12
- is InternalAesKey.Aes256Key -> 14
- }
-
- val expandedKey: Array = expandKey()
-
-
- var round = 0
- var completed : Boolean = false
- private set
-
- fun subBytes() {
- state.forEachIndexed { indexRow, row ->
- row.forEachIndexed { indexColumn, element ->
- state[indexRow][indexColumn] = getSBoxValue(element)
- }
- }
- }
-
- fun getSBoxValue(element: UByte): UByte {
- val firstDigit = (element / 16U).toInt()
- val secondDigit = (element % 16U).toInt()
- return sBox[firstDigit * 16 + secondDigit]
- }
-
- fun inverseSubBytes() {
- state.forEachIndexed { indexRow, row ->
- row.forEachIndexed { indexColumn, element ->
- state[indexRow][indexColumn] = getInverseSBoxValue(element)
- }
- }
- }
-
- fun getInverseSBoxValue(element: UByte): UByte {
- val firstDigit = (element / 16U).toInt()
- val secondDigit = (element % 16U).toInt()
- return inverseSBox[firstDigit * 16 + secondDigit]
- }
-
- fun shiftRows() {
- state[0] = ubyteArrayOf(state[0][0], state[0][1], state[0][2], state[0][3])
- state[1] = ubyteArrayOf(state[1][1], state[1][2], state[1][3], state[1][0])
- state[2] = ubyteArrayOf(state[2][2], state[2][3], state[2][0], state[2][1])
- state[3] = ubyteArrayOf(state[3][3], state[3][0], state[3][1], state[3][2])
- }
-
- fun inversShiftRows() {
- state[0] = ubyteArrayOf(state[0][0], state[0][1], state[0][2], state[0][3])
- state[1] = ubyteArrayOf(state[1][3], state[1][0], state[1][1], state[1][2])
- state[2] = ubyteArrayOf(state[2][2], state[2][3], state[2][0], state[2][1])
- state[3] = ubyteArrayOf(state[3][1], state[3][2], state[3][3], state[3][0])
- }
-
- fun mixColumns() {
- val stateMixed: Array = (0 until 4).map {
- UByteArray(4) { 0U }
- }.toTypedArray()
- for (c in 0..3) {
-
- stateMixed[0][c] = (2U gfm state[0][c]) xor (3U gfm state[1][c]) xor state[2][c] xor state[3][c]
- stateMixed[1][c] = state[0][c] xor (2U gfm state[1][c]) xor (3U gfm state[2][c]) xor state[3][c]
- stateMixed[2][c] = state[0][c] xor state[1][c] xor (2U gfm state[2][c]) xor (3U gfm state[3][c])
- stateMixed[3][c] = 3U gfm state[0][c] xor state[1][c] xor state[2][c] xor (2U gfm state[3][c])
- }
- stateMixed.copyInto(state)
- }
-
- fun inverseMixColumns() {
- val stateMixed: Array = (0 until 4).map {
- UByteArray(4) { 0U }
- }.toTypedArray()
- for (c in 0..3) {
- stateMixed[0][c] =
- (0x0eU gfm state[0][c]) xor (0x0bU gfm state[1][c]) xor (0x0dU gfm state[2][c]) xor (0x09U gfm state[3][c])
- stateMixed[1][c] =
- (0x09U gfm state[0][c]) xor (0x0eU gfm state[1][c]) xor (0x0bU gfm state[2][c]) xor (0x0dU gfm state[3][c])
- stateMixed[2][c] =
- (0x0dU gfm state[0][c]) xor (0x09U gfm state[1][c]) xor (0x0eU gfm state[2][c]) xor (0x0bU gfm state[3][c])
- stateMixed[3][c] =
- (0x0bU gfm state[0][c]) xor (0x0dU gfm state[1][c]) xor (0x09U gfm state[2][c]) xor (0x0eU gfm state[3][c])
- }
- stateMixed.copyInto(state)
- }
-
- fun galoisFieldAdd(first: UByte, second: UByte): UByte {
- return first xor second
- }
-
- fun galoisFieldMultiply(first: UByte, second: UByte): UByte {
- var result: UInt = 0U
- var firstInt = first.toUInt()
- var secondInt = second.toUInt()
- var carry: UInt = 0U
- for (i in 0..7) {
- if (secondInt and 0x01U == 1U) {
- result = result xor firstInt
- }
- carry = firstInt and 0x80U
- firstInt = firstInt shl 1
- if (carry == 0x80U) {
- firstInt = firstInt xor 0x001BU
- }
- secondInt = secondInt shr 1
- firstInt = firstInt and 0xFFU
- }
- return result.toUByte()
- }
-
- fun addRoundKey() {
-
- for (i in 0 until 4) {
- state[0][i] = state[0][i] xor expandedKey[round * 4 + i][0]
- state[1][i] = state[1][i] xor expandedKey[round * 4 + i][1]
- state[2][i] = state[2][i] xor expandedKey[round * 4 + i][2]
- state[3][i] = state[3][i] xor expandedKey[round * 4 + i][3]
- }
- round++
- }
-
- fun inverseAddRoundKey() {
- for (i in 0 until 4) {
- state[0][i] = state[0][i] xor expandedKey[round * 4 + i][0]
- state[1][i] = state[1][i] xor expandedKey[round * 4 + i][1]
- state[2][i] = state[2][i] xor expandedKey[round * 4 + i][2]
- state[3][i] = state[3][i] xor expandedKey[round * 4 + i][3]
- }
- round--
- }
-
- infix fun UInt.gfm(second: UByte): UByte {
- return galoisFieldMultiply(this.toUByte(), second)
- }
-
- fun expandKey(): Array {
- val expandedKey = (0 until 4 * (numberOfRounds + 1)).map {
- UByteArray(4) { 0U }
- }.toTypedArray()
- // First round
- for (i in 0 until aesKey.numberOf32BitWords) {
- expandedKey[i][0] = aesKey.keyArray[i * 4 + 0]
- expandedKey[i][1] = aesKey.keyArray[i * 4 + 1]
- expandedKey[i][2] = aesKey.keyArray[i * 4 + 2]
- expandedKey[i][3] = aesKey.keyArray[i * 4 + 3]
- }
-
- for (i in aesKey.numberOf32BitWords until 4 * (numberOfRounds + 1)) {
- val temp = expandedKey[i - 1].copyOf()
- if (i % aesKey.numberOf32BitWords == 0) {
- //RotWord
- val tempTemp = temp[0]
- temp[0] = temp[1]
- temp[1] = temp[2]
- temp[2] = temp[3]
- temp[3] = tempTemp
-
- //SubWord
- temp[0] = getSBoxValue(temp[0])
- temp[1] = getSBoxValue(temp[1])
- temp[2] = getSBoxValue(temp[2])
- temp[3] = getSBoxValue(temp[3])
-
- temp[0] = temp[0] xor rcon[i / aesKey.numberOf32BitWords]
-
- } else if (aesKey is InternalAesKey.Aes256Key && i % aesKey.numberOf32BitWords == 4) {
- temp[0] = getSBoxValue(temp[0])
- temp[1] = getSBoxValue(temp[1])
- temp[2] = getSBoxValue(temp[2])
- temp[3] = getSBoxValue(temp[3])
- }
- expandedKey[i] = expandedKey[i - aesKey.numberOf32BitWords].mapIndexed { index, it ->
- it xor temp[index]
- }.toUByteArray()
- clearArray(temp)
- }
- return expandedKey
- }
-
- fun encrypt(): UByteArray {
- if (completed) {
- throw RuntimeException("Encrypt can only be called once per Aes instance, since the state is cleared at the " +
- "end of the operation")
- }
- printState()
- addRoundKey()
- printState()
- for (i in 0 until numberOfRounds - 1) {
- subBytes()
- printState()
- shiftRows()
- printState()
- mixColumns()
- printState()
- addRoundKey()
- printState()
- }
-
- subBytes()
- printState()
- shiftRows()
- printState()
- addRoundKey()
- printState()
- val transposedMatrix = (0 until 4).map { outerCounter ->
- UByteArray(4) { 0U }
- }
- for (i in 0 until 4) {
- for (j in 0 until 4) {
- transposedMatrix[i][j] = state[j][i]
- }
- }
- state.forEach { clearArray(it) }
- completed = true
- return transposedMatrix.flattenToUByteArray()
- }
-
- fun decrypt(): UByteArray {
- if (completed) {
- throw RuntimeException("Decrypt can only be called once per Aes instance, since the state is cleared at the " +
- "end of the operation")
- }
- round = numberOfRounds
- printState()
- inverseAddRoundKey()
- printState()
- for (i in 0 until numberOfRounds - 1) {
- inversShiftRows()
- printState()
- inverseSubBytes()
- printState()
- inverseAddRoundKey()
- printState()
- inverseMixColumns()
- printState()
- }
-
- inversShiftRows()
- printState()
- inverseSubBytes()
- printState()
- inverseAddRoundKey()
- printState()
-
- val transposedMatrix = (0 until 4).map { outerCounter ->
- UByteArray(4) { 0U }
- }
- for (i in 0 until 4) {
- for (j in 0 until 4) {
- transposedMatrix[i][j] = state[j][i]
- }
- }
- state.forEach { clearArray(it) }
- completed = true
- return transposedMatrix.flattenToUByteArray()
- }
-
- private fun clearArray(array : UByteArray) {
- array.indices.forEach { array[it] = 0U }
- }
-
-
-
- private fun printState() {
- if (!debug) {
- return
- }
- println()
- state.forEach {
- println(it.joinToString(separator = " ") { it.toString(16) })
- }
- }
-
- private fun printState(specific : List) {
- if (!debug) {
- return
- }
- println()
- specific.forEach {
- println(it.joinToString(separator = " ") { it.toString(16) })
- }
- }
-
-
-}
-
-
-
-
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/ChaCha20Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/ChaCha20Pure.kt
deleted file mode 100644
index d475395..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/ChaCha20Pure.kt
+++ /dev/null
@@ -1,99 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.symmetric.LatinDancesCommon.littleEndianInverted
-import com.ionspin.kotlin.crypto.util.*
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-Jun-2020
- */
-internal class ChaCha20Pure {
- companion object {
- fun quarterRound(input: UIntArray, aPosition: Int, bPosition: Int, cPosition: Int, dPosition: Int) {
- input[aPosition] += input[bPosition]
- input[dPosition] = input[dPosition] xor input[aPosition]
- input[dPosition] = input[dPosition] rotateLeft 16
-
- input[cPosition] += input[dPosition]
- input[bPosition] = input[bPosition] xor input[cPosition]
- input[bPosition] = input[bPosition] rotateLeft 12
-
- input[aPosition] += input[bPosition]
- input[dPosition] = input[dPosition] xor input[aPosition]
- input[dPosition] = input[dPosition] rotateLeft 8
-
- input[cPosition] += input[dPosition]
- input[bPosition] = input[bPosition] xor input[cPosition]
- input[bPosition] = input[bPosition] rotateLeft 7
- }
-
- fun doubleRound(input: UIntArray) {
- quarterRound(input, 0, 4, 8, 12)
- quarterRound(input, 1, 5, 9, 13)
- quarterRound(input, 2, 6, 10, 14)
- quarterRound(input, 3, 7, 11, 15)
-
- quarterRound(input, 0, 5, 10, 15)
- quarterRound(input, 1, 6, 11, 12)
- quarterRound(input, 2, 7, 8, 13)
- quarterRound(input, 3, 4, 9, 14)
- }
-
- fun hash(initialState: UIntArray): UByteArray {
- val state = initialState.copyOf()
- for (i in 0 until 10) {
- doubleRound(state)
- }
- val result = UByteArray(64)
- for (i in 0 until 16) {
- littleEndianInverted(initialState[i] + state[i], result, i * 4)
- }
- return result
- }
-
- val sigma0_32 = 1634760805U //ubyteArrayOf(101U, 120U, 112U, 97U)
- val sigma1_32 = 857760878U //ubyteArrayOf(110U, 100U, 32U, 51U)
- val sigma2_32 = 2036477234U //ubyteArrayOf(50U, 45U, 98U, 121U)
- val sigma3_32 = 1797285236U //ubyteArrayOf(116U, 101U, 32U, 107U)
-
- fun xorWithKeystream(key: UByteArray, nonce: UByteArray, message: UByteArray, initialCounter: UInt): UByteArray {
- val ciphertext = UByteArray(message.size)
- val state = UIntArray(16) {
- when (it) {
- 0 -> sigma0_32
- 1 -> sigma1_32
- 2 -> sigma2_32
- 3 -> sigma3_32
- 4 -> key.fromLittleEndianArrayToUIntWithPosition(0)
- 5 -> key.fromLittleEndianArrayToUIntWithPosition(4)
- 6 -> key.fromLittleEndianArrayToUIntWithPosition(8)
- 7 -> key.fromLittleEndianArrayToUIntWithPosition(12)
- 8 -> key.fromLittleEndianArrayToUIntWithPosition(16)
- 9 -> key.fromLittleEndianArrayToUIntWithPosition(20)
- 10 -> key.fromLittleEndianArrayToUIntWithPosition(24)
- 11 -> key.fromLittleEndianArrayToUIntWithPosition(28)
- 12 -> initialCounter
- 13 -> nonce.fromLittleEndianArrayToUIntWithPosition(0)
- 14 -> nonce.fromLittleEndianArrayToUIntWithPosition(4)
- 15 -> nonce.fromLittleEndianArrayToUIntWithPosition(8)
- else -> 0U
- }
- }
- val blocks = message.size / 64
- val remainder = message.size % 64
- for (i in 0 until blocks) {
- hash(state).xorWithPositionsAndInsertIntoArray(0, 64, message, i * 64, ciphertext, i * 64)
- state[12] += 1U
- }
-
- hash(state).xorWithPositionsAndInsertIntoArray(
- 0, remainder,
- message, blocks * 64,
- ciphertext, blocks * 64
- )
- state.overwriteWithZeroes()
- return ciphertext
- }
- }
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/LatinDancesCommon.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/LatinDancesCommon.kt
deleted file mode 100644
index 202cf62..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/LatinDancesCommon.kt
+++ /dev/null
@@ -1,55 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-Jun-2020
- */
-
-
-
-
-object LatinDancesCommon {
-
- val _emitIntArray: IntArray = intArrayOf(1)
-
- fun littleEndian(
- input: UByteArray,
- byte0Position: Int,
- byte1Position: Int,
- byte2Position: Int,
- byte3Position: Int
- ): UInt {
- var uint = 0U
- uint = input[byte0Position].toUInt()
- uint = uint or (input[byte1Position].toUInt() shl 8)
- uint = uint or (input[byte2Position].toUInt() shl 16)
- uint = uint or (input[byte3Position].toUInt() shl 24)
-
- return uint
- }
-
- fun littleEndianInverted(
- input: UIntArray,
- startingPosition: Int,
- output: UByteArray,
- outputPosition: Int
- ) {
- output[outputPosition] = (input[startingPosition] and 0xFFU).toUByte()
- output[outputPosition + 1] = ((input[startingPosition] shr 8) and 0xFFU).toUByte()
- output[outputPosition + 2] = ((input[startingPosition] shr 16) and 0xFFU).toUByte()
- output[outputPosition + 3] = ((input[startingPosition] shr 24) and 0xFFU).toUByte()
- }
-
- fun littleEndianInverted(
- input: UInt,
- output: UByteArray,
- outputPosition: Int
- ) {
- output[outputPosition] = (input and 0xFFU).toUByte()
- output[outputPosition + 1] = ((input shr 8) and 0xFFU).toUByte()
- output[outputPosition + 2] = ((input shr 16) and 0xFFU).toUByte()
- output[outputPosition + 3] = ((input shr 24) and 0xFFU).toUByte()
- }
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/Salsa20Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/Salsa20Pure.kt
deleted file mode 100644
index 2fc3761..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/Salsa20Pure.kt
+++ /dev/null
@@ -1,122 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.symmetric.LatinDancesCommon.littleEndianInverted
-import com.ionspin.kotlin.crypto.util.*
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jun-2020
- */
-internal class Salsa20Pure {
- companion object {
- fun quarterRound(input: UIntArray, y0position: Int, y1position: Int, y2position: Int, y3position: Int) {
- input[y1position] = input[y1position] xor ((input[y0position] + input[y3position]) rotateLeft 7)
- input[y2position] = input[y2position] xor ((input[y1position] + input[y0position]) rotateLeft 9)
- input[y3position] = input[y3position] xor ((input[y2position] + input[y1position]) rotateLeft 13)
- input[y0position] = input[y0position] xor ((input[y3position] + input[y2position]) rotateLeft 18)
- }
-
- fun rowRound(input: UIntArray) {
- quarterRound(input, 0, 1, 2, 3)
- quarterRound(input, 5, 6, 7, 4)
- quarterRound(input, 10, 11, 8, 9)
- quarterRound(input, 15, 12, 13, 14)
- }
-
- fun columnRound(input: UIntArray) {
- quarterRound(input, 0, 4, 8, 12)
- quarterRound(input, 5, 9, 13, 1)
- quarterRound(input, 10, 14, 2, 6)
- quarterRound(input, 15, 3, 7, 11)
- }
-
- fun doubleRound(input: UIntArray) {
- columnRound(input)
- rowRound(input)
- }
-
-
-
- fun hash(initialState: UIntArray): UByteArray {
- val state = initialState.copyOf()
- for (i in 0 until 10) {
- doubleRound(state)
- }
- val result = UByteArray(64)
- for (i in 0 until 16) {
- littleEndianInverted(initialState[i] + state[i], result, i * 4)
- }
- return result
- }
-
- internal var sigma0_32_uint = 1634760805U //ubyteArrayOf(101U, 120U, 112U, 97U)
- internal var sigma1_32_uint = 857760878U //ubyteArrayOf(110U, 100U, 32U, 51U)
- internal var sigma2_32_uint = 2036477234U //ubyteArrayOf(50U, 45U, 98U, 121U)
- internal var sigma3_32_uint = 1797285236U //ubyteArrayOf(116U, 101U, 32U, 107U)
-
- val sigma0_32 = ubyteArrayOf(101U, 120U, 112U, 97U)
- val sigma1_32 = ubyteArrayOf(110U, 100U, 32U, 51U)
- val sigma2_32 = ubyteArrayOf(50U, 45U, 98U, 121U)
- val sigma3_32 = ubyteArrayOf(116U, 101U, 32U, 107U)
-
- val tau0_16 = ubyteArrayOf(101U, 120U, 112U, 97U)
- val tau1_16 = ubyteArrayOf(110U, 100U, 32U, 49U)
- val tau2_16 = ubyteArrayOf(54U, 45U, 98U, 121U)
- val tau3_16 = ubyteArrayOf(116U, 101U, 32U, 107U)
-
- fun expansion16(k: UByteArray, n: UByteArray) : UByteArray {
- return hash((tau0_16 + k + tau1_16 + n + tau2_16 + k + tau3_16).fromLittleEndianToUInt())
- }
-
- fun expansion32(key :UByteArray, nonce : UByteArray) : UByteArray {
- return hash((sigma0_32 + key.slice(0 until 16) + sigma1_32 + nonce + sigma2_32 + key.slice(16 until 32) + sigma3_32).fromLittleEndianToUInt())
- }
-
- fun encrypt(key : UByteArray, nonce: UByteArray, message: UByteArray) : UByteArray {
- val ciphertext = UByteArray(message.size)
- val state = UIntArray(16) {
- when (it) {
- 0 -> sigma0_32_uint
- 1 -> key.fromLittleEndianArrayToUIntWithPosition(0)
- 2 -> key.fromLittleEndianArrayToUIntWithPosition(4)
- 3 -> key.fromLittleEndianArrayToUIntWithPosition(8)
- 4 -> key.fromLittleEndianArrayToUIntWithPosition(12)
- 5 -> sigma1_32_uint
- 6 -> nonce.fromLittleEndianArrayToUIntWithPosition(0)
- 7 -> nonce.fromLittleEndianArrayToUIntWithPosition(4)
- 8 -> 0U
- 9 -> 0U
- 10 -> sigma2_32_uint
- 11 -> key.fromLittleEndianArrayToUIntWithPosition(16)
- 12 -> key.fromLittleEndianArrayToUIntWithPosition(20)
- 13 -> key.fromLittleEndianArrayToUIntWithPosition(24)
- 14 -> key.fromLittleEndianArrayToUIntWithPosition(28)
- 15 -> sigma3_32_uint
- else -> 0U
- }
- }
- val blocks = message.size / 64
- val remainder = message.size % 64
- for (i in 0 until blocks) {
- hash(state).xorWithPositionsAndInsertIntoArray(0, 64, message, i * 64, ciphertext, i * 64)
- state[8] += 1U
- if (state[8] == 0U) {
- state[9] += 1U
- }
- }
-
- hash(state).xorWithPositionsAndInsertIntoArray(
- 0, remainder,
- message, blocks * 64,
- ciphertext, blocks * 64)
- state.overwriteWithZeroes()
- return ciphertext
- }
-
- fun decrypt(key : UByteArray, nonce: UByteArray, ciphertext: UByteArray) : UByteArray {
- return encrypt(key, nonce, ciphertext)
- }
- }
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/XChaCha20Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/XChaCha20Pure.kt
deleted file mode 100644
index 5631cbd..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/XChaCha20Pure.kt
+++ /dev/null
@@ -1,179 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.util.fromLittleEndianArrayToUIntWithPosition
-import com.ionspin.kotlin.crypto.util.overwriteWithZeroes
-import com.ionspin.kotlin.crypto.util.xorWithPositionsAndInsertIntoArray
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jun-2020
- */
-class XChaCha20Pure(key: UByteArray, nonce: UByteArray, initialCounter: UInt = 0U) {
- companion object {
-
- fun hChacha(key: UByteArray, nonce: UByteArray) : UIntArray {
- val state = UIntArray(16) {
- when (it) {
- 0 -> ChaCha20Pure.sigma0_32
- 1 -> ChaCha20Pure.sigma1_32
- 2 -> ChaCha20Pure.sigma2_32
- 3 -> ChaCha20Pure.sigma3_32
- 4 -> key.fromLittleEndianArrayToUIntWithPosition(0)
- 5 -> key.fromLittleEndianArrayToUIntWithPosition(4)
- 6 -> key.fromLittleEndianArrayToUIntWithPosition(8)
- 7 -> key.fromLittleEndianArrayToUIntWithPosition(12)
- 8 -> key.fromLittleEndianArrayToUIntWithPosition(16)
- 9 -> key.fromLittleEndianArrayToUIntWithPosition(20)
- 10 -> key.fromLittleEndianArrayToUIntWithPosition(24)
- 11 -> key.fromLittleEndianArrayToUIntWithPosition(28)
- 12 -> nonce.fromLittleEndianArrayToUIntWithPosition(0)
- 13 -> nonce.fromLittleEndianArrayToUIntWithPosition(4)
- 14 -> nonce.fromLittleEndianArrayToUIntWithPosition(8)
- 15 -> nonce.fromLittleEndianArrayToUIntWithPosition(12)
- else -> 0U
- }
- }
- for (i in 0 until 10) {
- ChaCha20Pure.doubleRound(state)
- }
-
- val result = UIntArray(8) {
- when (it) {
- 0 -> state[0]
- 1 -> state[1]
- 2 -> state[2]
- 3 -> state[3]
- 4 -> state[12]
- 5 -> state[13]
- 6 -> state[14]
- 7 -> state[15]
- else -> throw RuntimeException("Invalid index $it")
- }
- }
- return result
-
- }
-
- fun xorWithKeystream(key: UByteArray, nonce: UByteArray, message: UByteArray, initialCounter: UInt = 0U): UByteArray {
-
- val ciphertext = UByteArray(message.size)
- val hChaChaKey = hChacha(key, nonce)
- val state = UIntArray(16) {
- when (it) {
- 0 -> ChaCha20Pure.sigma0_32
- 1 -> ChaCha20Pure.sigma1_32
- 2 -> ChaCha20Pure.sigma2_32
- 3 -> ChaCha20Pure.sigma3_32
- 4 -> hChaChaKey[0]
- 5 -> hChaChaKey[1]
- 6 -> hChaChaKey[2]
- 7 -> hChaChaKey[3]
- 8 -> hChaChaKey[4]
- 9 -> hChaChaKey[5]
- 10 -> hChaChaKey[6]
- 11 -> hChaChaKey[7]
- 12 -> initialCounter
- 13 -> 0U
- 14 -> nonce.fromLittleEndianArrayToUIntWithPosition(16)
- 15 -> nonce.fromLittleEndianArrayToUIntWithPosition(20)
- else -> 0U
- }
- }
- hChaChaKey.overwriteWithZeroes()
- val blocks = message.size / 64
- val remainder = message.size % 64
- for (i in 0 until blocks) {
- ChaCha20Pure.hash(state).xorWithPositionsAndInsertIntoArray(0, 64, message, i * 64, ciphertext, i * 64)
- state[12] += 1U
- if (state[12] == 0U) {
- state[13] += 1U
- }
- }
- ChaCha20Pure.hash(state).xorWithPositionsAndInsertIntoArray(
- 0, remainder,
- message, blocks * 64,
- ciphertext, blocks * 64
- )
- state.overwriteWithZeroes()
- return ciphertext
- }
-
- }
-
- val state: UIntArray
- val keystreamBuffer = UByteArray(64) { 0U}
- var keystreamRemainingCounter = 0
- var processedBytesSoFar = 0
-
- init {
- val hChaChaKey = hChacha(key, nonce)
- state = UIntArray(16) {
- when (it) {
- 0 -> ChaCha20Pure.sigma0_32
- 1 -> ChaCha20Pure.sigma1_32
- 2 -> ChaCha20Pure.sigma2_32
- 3 -> ChaCha20Pure.sigma3_32
- 4 -> hChaChaKey[0]
- 5 -> hChaChaKey[1]
- 6 -> hChaChaKey[2]
- 7 -> hChaChaKey[3]
- 8 -> hChaChaKey[4]
- 9 -> hChaChaKey[5]
- 10 -> hChaChaKey[6]
- 11 -> hChaChaKey[7]
- 12 -> initialCounter
- 13 -> 0U
- 14 -> nonce.fromLittleEndianArrayToUIntWithPosition(16)
- 15 -> nonce.fromLittleEndianArrayToUIntWithPosition(20)
- else -> 0U
- }
- }
- hChaChaKey.overwriteWithZeroes()
- }
-
- fun xorWithKeystream(data: UByteArray) : UByteArray {
- val ciphertext = UByteArray(data.size) { 0U }
- //First use remaining keystream
- var processedBytes = 0
- if (data.size > keystreamRemainingCounter) {
- keystreamBuffer.xorWithPositionsAndInsertIntoArray(
- 64 - keystreamRemainingCounter, 64,
- data, 0,
- ciphertext, 0
- )
- processedBytes += keystreamRemainingCounter
- keystreamRemainingCounter = 0
- }
- //Then do full blocks
- var remainingBytes = data.size - processedBytes
- for (i in 0 until remainingBytes / 64) {
- ChaCha20Pure.hash(state).xorWithPositionsAndInsertIntoArray(
- 0, 64,
- data, processedBytes,
- ciphertext, processedBytes
- )
- state[12] += 1U
- if (state[12] == 0U) {
- state[13] += 1U
- }
- processedBytes += 64
- }
- //Then do the remainder that didn't fit into 64byte blocks
- remainingBytes = data.size - processedBytes
- ChaCha20Pure.hash(state).copyInto(keystreamBuffer)
- state[12] += 1U
- if (state[12] == 0U) {
- state[13] += 1U
- }
- keystreamBuffer.xorWithPositionsAndInsertIntoArray(
- 0, remainingBytes,
- data, processedBytes,
- ciphertext, processedBytes
- )
- keystreamRemainingCounter = 64 - remainingBytes
- processedBytesSoFar += data.size
- return ciphertext
- }
-
-}
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/XSalsa20Pure.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/XSalsa20Pure.kt
deleted file mode 100644
index ca83a60..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/symmetric/XSalsa20Pure.kt
+++ /dev/null
@@ -1,105 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.util.fromLittleEndianArrayToUInt
-import com.ionspin.kotlin.crypto.util.fromLittleEndianArrayToUIntWithPosition
-import com.ionspin.kotlin.crypto.util.overwriteWithZeroes
-import com.ionspin.kotlin.crypto.util.xorWithPositionsAndInsertIntoArray
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-Jun-2020
- */
-internal class XSalsa20Pure {
- companion object {
- fun hSalsa(key: UByteArray, nonce: UByteArray): UIntArray {
- val state = UIntArray(16) {
- when (it) {
- 0 -> Salsa20Pure.sigma0_32.fromLittleEndianArrayToUInt()
- 1 -> key.fromLittleEndianArrayToUIntWithPosition(0)
- 2 -> key.fromLittleEndianArrayToUIntWithPosition(4)
- 3 -> key.fromLittleEndianArrayToUIntWithPosition(8)
- 4 -> key.fromLittleEndianArrayToUIntWithPosition(12)
- 5 -> Salsa20Pure.sigma1_32.fromLittleEndianArrayToUInt()
- 6 -> nonce.fromLittleEndianArrayToUIntWithPosition(0)
- 7 -> nonce.fromLittleEndianArrayToUIntWithPosition(4)
- 8 -> nonce.fromLittleEndianArrayToUIntWithPosition(8)
- 9 -> nonce.fromLittleEndianArrayToUIntWithPosition(12)
- 10 -> Salsa20Pure.sigma2_32.fromLittleEndianArrayToUInt()
- 11 -> key.fromLittleEndianArrayToUIntWithPosition(16)
- 12 -> key.fromLittleEndianArrayToUIntWithPosition(20)
- 13 -> key.fromLittleEndianArrayToUIntWithPosition(24)
- 14 -> key.fromLittleEndianArrayToUIntWithPosition(28)
- 15 -> Salsa20Pure.sigma3_32.fromLittleEndianArrayToUInt()
- else -> throw RuntimeException("Invalid index $it")
- }
- }
- for (i in 0 until 10) {
- Salsa20Pure.doubleRound(state)
- }
- val result = UIntArray(8) {
- when (it) {
- 0 -> state[0]
- 1 -> state[5]
- 2 -> state[10]
- 3 -> state[15]
- 4 -> state[6]
- 5 -> state[7]
- 6 -> state[8]
- 7 -> state[9]
- else -> throw RuntimeException("Invalid index $it")
- }
- }
- return result
-
- }
-
- fun encrypt(key: UByteArray, nonce: UByteArray, message: UByteArray): UByteArray {
- if (nonce.size != 24) {
- throw RuntimeException("Invalid nonce size. required 192 bits, got ${nonce.size * 8}")
- }
- val ciphertext = UByteArray(message.size)
- val hSalsaKey = hSalsa(key, nonce)
- val state = UIntArray(16) {
- when (it) {
- 0 -> Salsa20Pure.sigma0_32_uint
- 1 -> hSalsaKey[0]
- 2 -> hSalsaKey[1]
- 3 -> hSalsaKey[2]
- 4 -> hSalsaKey[3]
- 5 -> Salsa20Pure.sigma1_32_uint
- 6 -> nonce.fromLittleEndianArrayToUIntWithPosition(16) //Last 63 bit of 192 bit nonce
- 7 -> nonce.fromLittleEndianArrayToUIntWithPosition(20)
- 8 -> 0U
- 9 -> 0U
- 10 -> Salsa20Pure.sigma2_32_uint
- 11 -> hSalsaKey[4]
- 12 -> hSalsaKey[5]
- 13 -> hSalsaKey[6]
- 14 -> hSalsaKey[7]
- 15 -> Salsa20Pure.sigma3_32_uint
- else -> 0U
- }
- }
- hSalsaKey.overwriteWithZeroes()
- val blocks = message.size / 64
- val remainder = message.size % 64
- for (i in 0 until blocks) {
- Salsa20Pure.hash(state).xorWithPositionsAndInsertIntoArray(0, 64, message, i * 64, ciphertext, i * 64)
- state[8] += 1U
- if (state[8] == 0U) {
- state[9] += 1U
- }
- }
-
- Salsa20Pure.hash(state).xorWithPositionsAndInsertIntoArray(
- 0, remainder,
- message, blocks * 64,
- ciphertext, blocks * 64)
- state.overwriteWithZeroes()
- return ciphertext
- }
-
- }
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/util/Util.kt b/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/util/Util.kt
deleted file mode 100644
index 1dc57f9..0000000
--- a/multiplatform-crypto/src/commonMain/kotlin/com/ionspin/kotlin/crypto/util/Util.kt
+++ /dev/null
@@ -1,304 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_API_USAGE")
-
-package com.ionspin.kotlin.crypto.util
-
-//TODO Reorganize this, currently it's just a pile of useful helper functions
-
-val _emitIntArray: IntArray = intArrayOf(1)
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 15-Jul-2019
- */
-
-inline fun Array.chunked(sliceSize: Int): Array> {
- val last = this.size % sliceSize
- val hasLast = last != 0
- val numberOfSlices = this.size / sliceSize
-
-
- val result : MutableList> = MutableList>(0) { emptyList() }
-
- for (i in 0 until numberOfSlices) {
- result.add(this.slice(i * sliceSize until (i + 1) * sliceSize))
- }
- if (hasLast) {
- result.add(this.slice(numberOfSlices * sliceSize until this.size))
- }
-
- return result.map { it.toTypedArray() }.toTypedArray()
-
-}
-
-
-infix fun UInt.rotateRight(places: Int): UInt {
- return (this shr places) xor (this shl (32 - places))
-}
-
-
-infix fun ULong.rotateRight(places: Int): ULong {
- return (this shr places) xor (this shl (64 - places))
-}
-
-infix fun UInt.rotateLeft(places: Int): UInt {
- return (this shl places) xor (this shr (32 - places))
-}
-
-
-infix fun ULong.rotateLeft(places: Int): ULong {
- return (this shl places) xor (this shr (64 - places))
-}
-
-infix fun Array.xor(other : Array) : Array {
- if (this.size != other.size) {
- throw RuntimeException("Operands of different sizes are not supported yet")
- }
- return Array(this.size) { this[it] xor other[it] }
-}
-
-
-infix fun UByteArray.xor(other : UByteArray) : UByteArray {
- if (this.size != other.size) {
- throw RuntimeException("Operands of different sizes are not supported yet")
- }
- return UByteArray(this.size) { this[it] xor other[it] }
-}
-
-fun UByteArray.xorWithPositions(start: Int, end: Int, other : UByteArray, otherStart: Int) : UByteArray {
- return UByteArray(end - start) { this[start + it] xor other[otherStart + it] }
-}
-
-/**
- * Start index is included, end index is excluded
- */
-fun UByteArray.xorWithPositionsAndInsertIntoArray(
- start: Int, end: Int,
- other : UByteArray, otherStart: Int,
- targetArray: UByteArray, targetStart : Int
-) {
- val length = end - start
- for (i in 0 until length) {
- targetArray[targetStart + i] = this[start + i] xor other[otherStart + i]
- }
-}
-
-// UInt / Array utils
-
-fun UInt.toBigEndianUByteArray() : Array {
- return Array (4) {
- ((this shr (24 - (it * 8))) and 0xFFU).toUByte()
- }
-}
-
-fun UInt.toLittleEndianTypedUByteArray() : Array {
- return Array (4) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-
-fun UInt.toLittleEndianUByteArray() : UByteArray {
- return UByteArray (4) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-
-fun UIntArray.toLittleEndianUByteArray() : UByteArray {
- val result = UByteArray(size * 4)
- for (i in 0 until size) {
- val converted = this[i].toLittleEndianUByteArray()
- result[i * 4] = converted[0]
- result[i * 4 + 1] = converted[1]
- result[i * 4 + 2] = converted[2]
- result[i * 4 + 3] = converted[3]
- }
- return result
-}
-
-// UInt / Array utils
-
-fun ULong.toBigEndianUByteArray() : Array {
- return Array (8) {
- ((this shr (56 - (it * 8))) and 0xFFU).toUByte()
- }
-}
-
-fun ULong.toLittleEndianTypedUByteArray() : Array {
- return Array (8) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-
-fun ULong.toLittleEndianUByteArray() :UByteArray {
- return UByteArray (8) {
- ((this shr (it * 8)) and 0xFFU).toUByte()
- }
-}
-
-
-fun Array.fromLittleEndianArrayToULong() : ULong {
- if (this.size > 8) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var ulong = this.foldIndexed(0UL) { index, acc, uByte -> acc or (uByte.toULong() shl (index * 8))}
- return ulong
-}
-
-
-fun UByteArray.fromLittleEndianArrayToULong() : ULong {
- if (this.size > 8) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var ulong = this.foldIndexed(0UL) { index, acc, uByte -> acc or (uByte.toULong() shl (index * 8))}
- return ulong
-}
-
-fun UByteArray.arrayChunked(sliceSize: Int): List {
- val last = this.size % sliceSize
- val hasLast = last != 0
- val numberOfSlices = this.size / sliceSize
-
-
- val result : MutableList = MutableList(0) { ubyteArrayOf() }
-
- for (i in 0 until numberOfSlices) {
- result.add(this.sliceArray(i * sliceSize until (i + 1) * sliceSize))
- }
- if (hasLast) {
- result.add(this.sliceArray(numberOfSlices * sliceSize until this.size))
- }
-
- return result
-}
-
-
-
-fun Array.fromBigEndianArrayToULong() : ULong {
- if (this.size > 8) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var ulong = this.foldIndexed(0UL) {
- index, acc, uByte ->
- val res = acc or (uByte.toULong() shl (56 - (index * 8)))
- res
-
- }
- return ulong
-}
-
-
-fun Array.fromLittleEndianArrayToUInt() : UInt {
- if (this.size > 4) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var uint = this.foldIndexed(0U) { index, acc, uByte -> acc or (uByte.toUInt() shl (index * 8))}
- return uint
-}
-
-
-fun UByteArray.fromLittleEndianArrayToUInt() : UInt {
- if (this.size > 4) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var uint = this.foldIndexed(0U) { index, acc, uByte -> acc or (uByte.toUInt() shl (index * 8))}
- return uint
-}
-
-fun UByteArray.fromLittleEndianArrayToUIntWithPosition(position: Int) : UInt{
- var uint = 0U
- for (i in 0 until 4) {
- uint = uint or (this[position + i].toUInt() shl (i * 8))
- }
- return uint
-}
-
-fun UByteArray.fromBigEndianArrayToUInt() : UInt{
- var uint = 0U
- for (i in 0 until 4) {
- uint = uint shl 8 or (this[i].toUInt())
- }
- return uint
-}
-
-fun UByteArray.fromBigEndianArrayToUIntWithPosition(position: Int) : UInt{
- var uint = 0U
- for (i in 0 until 4) {
- uint = uint shl 8 or (this[position + i].toUInt())
- }
- return uint
-}
-
-fun UByteArray.insertUIntAtPositionAsLittleEndian(position: Int, value: UInt) {
- for (i in position until position + 4) {
- this[i] = ((value shr (i * 8)) and 0xFFU).toUByte()
- }
-}
-
-fun UByteArray.insertUIntAtPositionAsBigEndian(position: Int, value: UInt) {
- for (i in position until position + 4) {
- this[i] = ((value shr (24 - i * 8)) and 0xFFU).toUByte()
- }
-}
-
-fun UByteArray.fromLittleEndianToUInt() : UIntArray {
- if (size % 4 != 0) {
- throw RuntimeException("Invalid size (not divisible by 4)")
- }
- return UIntArray(size / 4) {
- fromLittleEndianArrayToUIntWithPosition(it * 4)
- }
-}
-
-
-fun UByteArray.fromBigEndianToUInt() : UIntArray {
- if (size % 4 != 0) {
- throw RuntimeException("Invalid size (not divisible by 4)")
- }
- return UIntArray(size / 4) {
- fromBigEndianArrayToUIntWithPosition(it * 4)
- }
-}
-
-fun Array.fromBigEndianArrayToUInt() : UInt {
- if (this.size > 4) {
- throw RuntimeException("ore than 8 bytes in input, potential overflow")
- }
- var uint = this.foldIndexed(0U) { index, acc, uByte -> acc or (uByte.toUInt() shl (24 - (index * 8))) }
- return uint
-}
-
-
-operator fun UInt.plus(other : UByteArray) : UByteArray {
- return this.toLittleEndianUByteArray() + other
-}
-
-//AES Flatten
-fun Collection.flattenToUByteArray(): UByteArray {
- val result = UByteArray(sumBy { it.size })
- var position = 0
- for (element in this) {
- element.forEach { uByte ->
- result[position] = uByte
- position++
- }
- }
- return result
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/ReadmeTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/ReadmeTest.kt
deleted file mode 100644
index 301eeb2..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/ReadmeTest.kt
+++ /dev/null
@@ -1,168 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.hash.blake2b.Blake2bPure
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.hash.sha.Sha256Pure
-import com.ionspin.kotlin.crypto.hash.sha.Sha512Pure
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Pure
-import com.ionspin.kotlin.crypto.keyderivation.argon2.ArgonType
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import com.ionspin.kotlin.crypto.util.testBlocking
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.Test
-import kotlin.test.assertEquals
-import kotlin.test.assertTrue
-import kotlin.time.ExperimentalTime
-import kotlin.time.measureTime
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 20-Jul-2019
- */
-
-
-class ReadmeTest {
-
- @Test
- fun blake2bObjectExample() {
- val input = "abc"
- val result = Blake2bPure.digest(input.encodeToUByteArray())
- //@formatter:off
- val expectedResult = ubyteArrayOf(
- 0xBAU,0x80U,0xA5U,0x3FU,0x98U,0x1CU,0x4DU,0x0DU,0x6AU,0x27U,0x97U,0xB6U,0x9FU,0x12U,0xF6U,0xE9U,
- 0x4CU,0x21U,0x2FU,0x14U,0x68U,0x5AU,0xC4U,0xB7U,0x4BU,0x12U,0xBBU,0x6FU,0xDBU,0xFFU,0xA2U,0xD1U,
- 0x7DU,0x87U,0xC5U,0x39U,0x2AU,0xABU,0x79U,0x2DU,0xC2U,0x52U,0xD5U,0xDEU,0x45U,0x33U,0xCCU,0x95U,
- 0x18U,0xD3U,0x8AU,0xA8U,0xDBU,0xF1U,0x92U,0x5AU,0xB9U,0x23U,0x86U,0xEDU,0xD4U,0x00U,0x99U,0x23U
- )
- //@formatter:on
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-
- @Test
- fun blake2bInstanceExample() {
- val test = "abc"
- val key = "key"
- val blake2b = Blake2bPure(key)
- blake2b.update(test)
- val result = blake2b.digest()
-
- assertTrue {
- result.isNotEmpty()
- }
- val expectedResult = ("5c6a9a4ae911c02fb7e71a991eb9aea371ae993d4842d206e" +
- "6020d46f5e41358c6d5c277c110ef86c959ed63e6ecaaaceaaff38019a43264ae06acf73b9550b1")
- .hexStringToUByteArray()
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-
-
- @Test
- fun sha256Example() {
- val input = "abc"
- val result = Sha256Pure.digest(input.encodeToUByteArray())
- val expectedResult = "ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
-
-
- }
-
-
- @Test
- fun sha512Example() {
- val input = "abc"
- val result = Sha512Pure.digest(inputMessage = input.encodeToUByteArray())
- println(result.map { it.toString(16) })
- val expectedResult = "ddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a" +
- "2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
-
-
- }
-
-
- @Test
- fun sha256UpdatableExample() {
- val sha256 = Sha256Pure()
- sha256.update("abc")
- val result = sha256.digest()
- val expectedResult = "ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun sha512UpdatableExample() {
- val sha512 = Sha512Pure()
- sha512.update("abc")
- val result = sha512.digest()
- val expectedResult = "ddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a" +
- "2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
-
-
- }
-
- @ExperimentalTime
- @Test
- fun argon2StringExample() = testBlocking {
- val argon2Instance = Argon2Pure(
- password = "Password",
- salt = "RandomSalt",
- parallelism = 1,
- tagLength = 64U,
- requestedMemorySize = 4096U,
- numberOfIterations = 2,
- key = "",
- associatedData = "",
- argonType = ArgonType.Argon2id
- )
- val time = measureTime {
- val tag = argon2Instance.derive()
- val tagString = tag.map { it.toString(16).padStart(2, '0') }.joinToString(separator = "")
- val expectedTagString = "c19db7e22d1480702b943872c863baf8c43b53d0c3e2c782cd07bfc613eda159233bd821a945c239c5085c70257f7c93d8a809f81c4af367f4ad8f0443a8fc47"
- println("Tag: ${tagString}")
- assertEquals(tagString, expectedTagString)
- }
- println("Time $time")
-
- }
-
- @Test
- fun debugTest() {
- val result = Blake2bPure.digest("test".encodeToUByteArray())
- println(result.toHexString())
- }
-
-
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/SRNGTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/SRNGTest.kt
deleted file mode 100644
index dba842a..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/SRNGTest.kt
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-class SRNGTest {
- @Test
- fun testSrng() {
- //Just a sanity test, need to add better srng tests.
- val randomBytes1 = SRNG.getRandomBytes(10)
- val randomBytes2 = SRNG.getRandomBytes(10)
- randomBytes1.forEach { println("RB1: $it")}
- randomBytes2.forEach { println("RB2: $it")}
- assertTrue { !randomBytes1.contentEquals(randomBytes2) }
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/UtilTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/UtilTest.kt
deleted file mode 100644
index aa90414..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/UtilTest.kt
+++ /dev/null
@@ -1,114 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import com.ionspin.kotlin.crypto.util.chunked
-import com.ionspin.kotlin.crypto.util.fromBigEndianArrayToULong
-import com.ionspin.kotlin.crypto.util.fromLittleEndianArrayToULong
-import com.ionspin.kotlin.crypto.util.toBigEndianUByteArray
-import com.ionspin.kotlin.crypto.util.toLittleEndianTypedUByteArray
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-class UtilTest {
-
- @Test
- fun testSlicer() {
- val array = arrayOf(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17)
- val chunked = array.chunked(2)
- assertTrue {
- chunked.size == 9 && chunked[8][0] == 17
- }
- }
-
- @Test
- fun testUIntToBigEndianArray() {
- assertTrue {
- val original = 1U
- val converted = original.toBigEndianUByteArray()
- converted[0] = 1U
- true
- }
- assertTrue {
- val original = 0xAABBCCDDU
- val converted = original.toBigEndianUByteArray()
- converted[0] == 0xAAU.toUByte() &&
- converted[1] == 0xBBU.toUByte() &&
- converted[2] == 0xCCU.toUByte() &&
- converted[3] == 0xDDU.toUByte()
-
- }
- }
-
- @Test
- fun testUIntToLittleEndianArray() {
- assertTrue {
- val original = 1U
- val converted = original.toLittleEndianTypedUByteArray()
- converted[3] = 1U
- true
- }
- assertTrue {
- val original = 0xAABBCCDDU
- val converted = original.toLittleEndianTypedUByteArray()
- converted[0] == 0xDDU.toUByte() &&
- converted[1] == 0xCCU.toUByte() &&
- converted[2] == 0xBBU.toUByte() &&
- converted[3] == 0xAAU.toUByte()
-
- }
- assertTrue {
- val original = 123456U
- val converted = original.toLittleEndianTypedUByteArray()
- converted[0] == 0x40U.toUByte() &&
- converted[1] == 0xE2U.toUByte() &&
- converted[2] == 0x01U.toUByte() &&
- converted[3] == 0x00U.toUByte()
-
- }
- }
-
- @Test
- fun testFromBigEndianByteArrayToLong() {
-
- assertTrue {
- val ubyteArray = ubyteArrayOf(0xA1U, 0xA2U, 0xB1U, 0xB2U, 0xC1U, 0xC2U, 0xD1U, 0xD2U).toTypedArray()
- val expected = 0xA1A2B1B2C1C2D1D2U
- val reconstructed = ubyteArray.fromBigEndianArrayToULong();
- reconstructed == expected
- }
-
- }
-
- @Test
- fun testFromLittleEndianByteArrayToLong() {
-
- assertTrue {
- val ubyteArray = ubyteArrayOf(0xA1U, 0xA2U, 0xB1U, 0xB2U, 0xC1U, 0xC2U, 0xD1U, 0xD2U).toTypedArray()
- val expected = 0xD2D1C2C1B2B1A2A1UL
- val reconstructed = ubyteArray.fromLittleEndianArrayToULong();
- reconstructed == expected
- }
-
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/ChaCha20Poly1305Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/ChaCha20Poly1305Test.kt
deleted file mode 100644
index ca0a763..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/ChaCha20Poly1305Test.kt
+++ /dev/null
@@ -1,56 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jun-2020
- */
-class ChaCha20Poly1305Test {
-
-
-
- @Test
- fun chaCha20Poly1305() {
- val message = ("Ladies and Gentlemen of the class of '99: If I could offer you " +
- "only one tip for the future, sunscreen would be it.").encodeToUByteArray()
-
- val associatedData = ubyteArrayOf(
- 0x50U, 0x51U, 0x52U, 0x53U, 0xc0U, 0xc1U, 0xc2U, 0xc3U, 0xc4U, 0xc5U, 0xc6U, 0xc7U
- )
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU,
- )
-
- val nonce = ubyteArrayOf(
- 0x07U, 0x00U, 0x00U, 0x00U, 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U
- )
- //Ciphertext + Poly1305TAG
- val expected = ubyteArrayOf(
- 0xd3U, 0x1aU, 0x8dU, 0x34U, 0x64U, 0x8eU, 0x60U, 0xdbU, 0x7bU, 0x86U, 0xafU, 0xbcU, 0x53U, 0xefU, 0x7eU, 0xc2U,
- 0xa4U, 0xadU, 0xedU, 0x51U, 0x29U, 0x6eU, 0x08U, 0xfeU, 0xa9U, 0xe2U, 0xb5U, 0xa7U, 0x36U, 0xeeU, 0x62U, 0xd6U,
- 0x3dU, 0xbeU, 0xa4U, 0x5eU, 0x8cU, 0xa9U, 0x67U, 0x12U, 0x82U, 0xfaU, 0xfbU, 0x69U, 0xdaU, 0x92U, 0x72U, 0x8bU,
- 0x1aU, 0x71U, 0xdeU, 0x0aU, 0x9eU, 0x06U, 0x0bU, 0x29U, 0x05U, 0xd6U, 0xa5U, 0xb6U, 0x7eU, 0xcdU, 0x3bU, 0x36U,
- 0x92U, 0xddU, 0xbdU, 0x7fU, 0x2dU, 0x77U, 0x8bU, 0x8cU, 0x98U, 0x03U, 0xaeU, 0xe3U, 0x28U, 0x09U, 0x1bU, 0x58U,
- 0xfaU, 0xb3U, 0x24U, 0xe4U, 0xfaU, 0xd6U, 0x75U, 0x94U, 0x55U, 0x85U, 0x80U, 0x8bU, 0x48U, 0x31U, 0xd7U, 0xbcU,
- 0x3fU, 0xf4U, 0xdeU, 0xf0U, 0x8eU, 0x4bU, 0x7aU, 0x9dU, 0xe5U, 0x76U, 0xd2U, 0x65U, 0x86U, 0xceU, 0xc6U, 0x4bU,
- 0x61U, 0x16U, 0x1aU, 0xe1U, 0x0bU, 0x59U, 0x4fU, 0x09U, 0xe2U, 0x6aU, 0x7eU, 0x90U, 0x2eU, 0xcbU, 0xd0U, 0x60U,
- 0x06U, 0x91U
- )
- val result = ChaCha20Poly1305Pure.encrypt(key, nonce, message, associatedData)
- result.hexColumsPrint()
- assertTrue {
- result.contentEquals(expected)
- }
-
- }
-
-
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Test.kt
deleted file mode 100644
index c186102..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/authenticated/XChaCha20Poly1305Test.kt
+++ /dev/null
@@ -1,211 +0,0 @@
-package com.ionspin.kotlin.crypto.authenticated
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import kotlin.test.Ignore
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jun-2020
- */
-class XChaCha20Poly1305Test {
-
-
- @Test
- fun xChaCha20Poly1305() {
- assertTrue {
- val message = ("Ladies and Gentlemen of the class of '99: If I could offer you " +
- "only one tip for the future, sunscreen would be it.").encodeToUByteArray()
-
- val associatedData = ubyteArrayOf(
- 0x50U, 0x51U, 0x52U, 0x53U, 0xc0U, 0xc1U, 0xc2U, 0xc3U, 0xc4U, 0xc5U, 0xc6U, 0xc7U
- )
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU,
- )
-
- val nonce = ubyteArrayOf(
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x57U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x6dU, 0x17U, 0x9dU, 0x3eU, 0x83U, 0xd4U, 0x3bU,
- 0x95U, 0x76U, 0x57U, 0x94U, 0x93U, 0xc0U, 0xe9U, 0x39U,
- 0x57U, 0x2aU, 0x17U, 0x00U, 0x25U, 0x2bU, 0xfaU, 0xccU,
- 0xbeU, 0xd2U, 0x90U, 0x2cU, 0x21U, 0x39U, 0x6cU, 0xbbU,
- 0x73U, 0x1cU, 0x7fU, 0x1bU, 0x0bU, 0x4aU, 0xa6U, 0x44U,
- 0x0bU, 0xf3U, 0xa8U, 0x2fU, 0x4eU, 0xdaU, 0x7eU, 0x39U,
- 0xaeU, 0x64U, 0xc6U, 0x70U, 0x8cU, 0x54U, 0xc2U, 0x16U,
- 0xcbU, 0x96U, 0xb7U, 0x2eU, 0x12U, 0x13U, 0xb4U, 0x52U,
- 0x2fU, 0x8cU, 0x9bU, 0xa4U, 0x0dU, 0xb5U, 0xd9U, 0x45U,
- 0xb1U, 0x1bU, 0x69U, 0xb9U, 0x82U, 0xc1U, 0xbbU, 0x9eU,
- 0x3fU, 0x3fU, 0xacU, 0x2bU, 0xc3U, 0x69U, 0x48U, 0x8fU,
- 0x76U, 0xb2U, 0x38U, 0x35U, 0x65U, 0xd3U, 0xffU, 0xf9U,
- 0x21U, 0xf9U, 0x66U, 0x4cU, 0x97U, 0x63U, 0x7dU, 0xa9U,
- 0x76U, 0x88U, 0x12U, 0xf6U, 0x15U, 0xc6U, 0x8bU, 0x13U,
- 0xb5U, 0x2eU, 0xc0U, 0x87U, 0x59U, 0x24U, 0xc1U, 0xc7U,
- 0x98U, 0x79U, 0x47U, 0xdeU, 0xafU, 0xd8U, 0x78U, 0x0aU,
- 0xcfU, 0x49U
- )
- val encrypted = XChaCha20Poly1305Pure.encrypt(key, nonce, message, associatedData)
- val decrypted = XChaCha20Poly1305Pure.decrypt(key, nonce, encrypted, associatedData)
-
- encrypted.contentEquals(expected) && decrypted.contentEquals(message)
- }
-
- assertTrue {
- val message = ubyteArrayOf(
- 0x00U
- )
- val associatedData = ubyteArrayOf(
- 0x00U
- )
- val key = ubyteArrayOf(
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- )
-
- val nonce = ubyteArrayOf(
- 0x00U, 0x01U, 0x02U, 0x03U, 0x04U, 0x05U, 0x06U, 0x07U, 0x08U, 0x09U, 0x0aU, 0x0bU,
- 0x0cU, 0x0dU, 0x0eU, 0x0fU, 0x10U, 0x11U, 0x12U, 0x13U, 0x14U, 0x15U, 0x16U, 0x17U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x3bU, 0x8aU, 0xd7U, 0xa1U, 0x9dU, 0xe8U, 0xc4U, 0x55U,
- 0x84U, 0x6fU, 0xfcU, 0x75U, 0x31U, 0xbfU, 0x0cU, 0x2dU
- )
- val encrypted = XChaCha20Poly1305Pure.encrypt(key, nonce, message, associatedData)
- val decrypted = XChaCha20Poly1305Pure.decrypt(key, nonce, encrypted, associatedData)
-
- encrypted.contentEquals(expected) && decrypted.contentEquals(message)
- }
-
-
- }
- @Ignore() //"Will fail because nonce is not a parameter any more"
- @Test
- fun updateableXChaCha20Poly1305() {
- assertTrue {
- val message = ("Ladies and Gentlemen of the class of '99: If I could offer you " +
- "only one tip for the future, sunscreen would be it.").encodeToUByteArray()
-
- val associatedData = ubyteArrayOf(
- 0x50U, 0x51U, 0x52U, 0x53U, 0xc0U, 0xc1U, 0xc2U, 0xc3U, 0xc4U, 0xc5U, 0xc6U, 0xc7U
- )
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU,
- )
-
- val nonce = ubyteArrayOf(
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x57U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x6dU, 0x17U, 0x9dU, 0x3eU, 0x83U, 0xd4U, 0x3bU,
- 0x95U, 0x76U, 0x57U, 0x94U, 0x93U, 0xc0U, 0xe9U, 0x39U,
- 0x57U, 0x2aU, 0x17U, 0x00U, 0x25U, 0x2bU, 0xfaU, 0xccU,
- 0xbeU, 0xd2U, 0x90U, 0x2cU, 0x21U, 0x39U, 0x6cU, 0xbbU,
- 0x73U, 0x1cU, 0x7fU, 0x1bU, 0x0bU, 0x4aU, 0xa6U, 0x44U,
- 0x0bU, 0xf3U, 0xa8U, 0x2fU, 0x4eU, 0xdaU, 0x7eU, 0x39U,
- 0xaeU, 0x64U, 0xc6U, 0x70U, 0x8cU, 0x54U, 0xc2U, 0x16U,
- 0xcbU, 0x96U, 0xb7U, 0x2eU, 0x12U, 0x13U, 0xb4U, 0x52U,
- 0x2fU, 0x8cU, 0x9bU, 0xa4U, 0x0dU, 0xb5U, 0xd9U, 0x45U,
- 0xb1U, 0x1bU, 0x69U, 0xb9U, 0x82U, 0xc1U, 0xbbU, 0x9eU,
- 0x3fU, 0x3fU, 0xacU, 0x2bU, 0xc3U, 0x69U, 0x48U, 0x8fU,
- 0x76U, 0xb2U, 0x38U, 0x35U, 0x65U, 0xd3U, 0xffU, 0xf9U,
- 0x21U, 0xf9U, 0x66U, 0x4cU, 0x97U, 0x63U, 0x7dU, 0xa9U,
- 0x76U, 0x88U, 0x12U, 0xf6U, 0x15U, 0xc6U, 0x8bU, 0x13U,
- 0xb5U, 0x2eU, 0xc0U, 0x87U, 0x59U, 0x24U, 0xc1U, 0xc7U,
- 0x98U, 0x79U, 0x47U, 0xdeU, 0xafU, 0xd8U, 0x78U, 0x0aU,
- 0xcfU, 0x49U
- )
-// val xChaChaPoly = XChaCha20Poly1305Pure(key, associatedData) val firstChunk =
-// xChaChaPoly.encryptPartialData(message) val finalChunk = xChaChaPoly.finishEncryption().first val result =
-// firstChunk + finalChunk result.contentEquals(expected)
- 1 == 1
- }
-
- assertTrue {
- val message = ubyteArrayOf(
- 0x00U
- )
- val associatedData = ubyteArrayOf(
- 0x00U
- )
- val key = ubyteArrayOf(
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U,
- )
-
- val nonce = ubyteArrayOf(
- 0x00U, 0x01U, 0x02U, 0x03U, 0x04U, 0x05U, 0x06U, 0x07U, 0x08U, 0x09U, 0x0aU, 0x0bU,
- 0x0cU, 0x0dU, 0x0eU, 0x0fU, 0x10U, 0x11U, 0x12U, 0x13U, 0x14U, 0x15U, 0x16U, 0x17U,
- )
-
- val expected = ubyteArrayOf(
- 0xbdU, 0x3bU, 0x8aU, 0xd7U, 0xa1U, 0x9dU, 0xe8U, 0xc4U, 0x55U,
- 0x84U, 0x6fU, 0xfcU, 0x75U, 0x31U, 0xbfU, 0x0cU, 0x2dU
- )
-// val xChaChaPoly = XChaCha20Poly1305Pure(key, associatedData)
-// val firstChunk = xChaChaPoly.encryptPartialData(message)
-// val finalChunk = xChaChaPoly.finishEncryption().first
-// val result = firstChunk + finalChunk
-// result.contentEquals(expected)
- 1 == 1
- }
-
-
- }
-
- @Test
- fun multipartXChaCha20Poly1305() {
- val key = UByteArray(32) { 0U}
-
- val state = ubyteArrayOf(
- 0x2DU, 0xDBU, 0xC7U, 0xB2U, 0x03U, 0xBCU, 0xC3U, 0x22U, 0xBDU, 0x0CU, 0xBAU, 0x82U, 0xADU, 0x77U, 0x79U, 0x44U,
- 0xE6U, 0x8FU, 0xA9U, 0x94U, 0x89U, 0xB1U, 0xDFU, 0xBEU, 0x00U, 0x9FU, 0x69U, 0xECU, 0x21U, 0x88U, 0x47U, 0x55U,
- 0x01U, 0x00U, 0x00U, 0x00U, 0xC5U, 0x55U, 0x06U, 0x38U, 0xEBU, 0xA3U, 0x12U, 0x7BU, 0x00U, 0x00U, 0x00U, 0x00U,
- 0x00U, 0x00U, 0x00U, 0x00U,
- )
- val header = ubyteArrayOf(
- 0x49U, 0x62U, 0x22U, 0x03U, 0xB7U, 0x46U, 0x11U, 0x97U, 0x8FU, 0x46U, 0x4AU, 0x3BU, 0x2FU, 0x2AU, 0x81U, 0x03U,
- 0xC5U, 0x55U, 0x06U, 0x38U, 0xEBU, 0xA3U, 0x12U, 0x7BU,
- )
- val expected = ubyteArrayOf(
- 0xAFU, 0xD3U, 0x2DU, 0x59U, 0xB8U, 0xC4U, 0x66U, 0x2EU, 0x47U, 0x29U, 0xC6U, 0xF9U, 0x93U, 0x4BU, 0x09U, 0x27U,
- 0x24U, 0xDDU, 0xF3U, 0x05U, 0x48U, 0x94U, 0x67U, 0x10U, 0x00U, 0x21U, 0x85U, 0x22U, 0x96U, 0x3CU, 0xCEU, 0x8EU,
- 0xB7U, 0x53U, 0x9DU, 0x46U, 0xF5U, 0x3CU, 0x5EU, 0x48U, 0x9BU, 0x8CU, 0x13U, 0xB7U, 0x28U, 0x6BU, 0xB3U, 0x6CU,
- 0x3AU, 0x04U, 0xB7U, 0x25U, 0xB9U, 0x50U, 0x45U, 0x08U, 0x0BU, 0x89U, 0xA2U, 0x0FU, 0x70U, 0xCCU, 0x60U, 0x1BU,
- 0xC3U, 0x17U, 0x35U, 0x9FU, 0xAEU, 0x82U, 0x51U, 0x43U, 0x1BU, 0x9DU, 0x53U, 0x9EU, 0xE2U, 0xAFU, 0x20U, 0x1FU,
- 0xFDU, 0x03U, 0x59U, 0x11U, 0x51U, 0x9EU, 0xACU, 0x83U, 0xCDU, 0x78U, 0xD1U, 0xD0U, 0xE5U, 0xD7U, 0x0EU, 0x41U,
- 0xDEU, 0xFBU, 0x5CU, 0x7FU, 0x1CU, 0x26U, 0x32U, 0x2CU, 0x51U, 0xF6U, 0xEFU, 0xC6U, 0x34U, 0xC4U, 0xACU, 0x6CU,
- 0xE8U, 0xF9U, 0x4BU, 0xABU, 0xA3U,
- )
-
- val xcha = XChaCha20Poly1305Pure(key, header)
- //Verify the state is correctly created
- assertTrue {
- xcha.calcKey.contentEquals(state.sliceArray(0 until 32))
- xcha.calcNonce.contentEquals(state.sliceArray(32 until 44))
- }
- val data = UByteArray(100) { 0U }
- xcha.streamEncrypt(data, ubyteArrayOf(), 0U).hexColumsPrint()
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2KATTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2KATTest.kt
deleted file mode 100644
index 6e86d56..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2KATTest.kt
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_UNSIGNED_LITERALS", "EXPERIMENTAL_API_USAGE")
-
-package com.ionspin.kotlin.crypto.hash.argon
-
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Pure
-import com.ionspin.kotlin.crypto.keyderivation.argon2.ArgonType
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Known Answer.. TestTest
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 10-May-2020
- */
-
-class Argon2KATTest {
-
- @Test
- fun argon2dKATTest() {
- val expected : UByteArray = ubyteArrayOf(
- 0x51U, 0x2BU, 0x39U, 0x1BU, 0x6FU, 0x11U, 0x62U, 0x97U,
- 0x53U, 0x71U, 0xD3U, 0x09U, 0x19U, 0x73U, 0x42U, 0x94U,
- 0xF8U, 0x68U, 0xE3U, 0xBEU, 0x39U, 0x84U, 0xF3U, 0xC1U,
- 0xA1U, 0x3AU, 0x4DU, 0xB9U, 0xFAU, 0xBEU, 0x4AU, 0xCBU
- )
-
-
- val memory = 32U //KiB
- val iterations = 3
- val parallelism = 4U
- val tagLength = 32U
- val password: UByteArray = ubyteArrayOf(
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U
- )
- val salt: UByteArray = ubyteArrayOf(0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U)
- val secret: UByteArray = ubyteArrayOf(0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U)
- val associatedData: UByteArray = ubyteArrayOf(0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U)
-
- val digest = Argon2Pure(
- password,
- salt,
- parallelism.toInt(),
- tagLength,
- memory,
- iterations,
- secret,
- associatedData,
- ArgonType.Argon2d
- )
- val result = digest.derive()
- result.hexColumsPrint(8)
- assertTrue { expected.contentEquals(result) }
-
- }
-
- @Test
- fun argon2iKATTest() {
- val expected : UByteArray = ubyteArrayOf(
- 0xc8U, 0x14U, 0xd9U, 0xd1U, 0xdcU, 0x7fU, 0x37U, 0xaaU,
- 0x13U, 0xf0U, 0xd7U, 0x7fU, 0x24U, 0x94U, 0xbdU, 0xa1U,
- 0xc8U, 0xdeU, 0x6bU, 0x01U, 0x6dU, 0xd3U, 0x88U, 0xd2U,
- 0x99U, 0x52U, 0xa4U, 0xc4U, 0x67U, 0x2bU, 0x6cU, 0xe8U
- )
-
-
- val memory = 32U //KiB
- val iterations = 3
- val parallelism = 4U
- val tagLength = 32U
- val password: UByteArray = ubyteArrayOf(
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U
- )
- val salt: UByteArray = ubyteArrayOf(0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U)
- val secret: UByteArray = ubyteArrayOf(0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U)
- val associatedData: UByteArray = ubyteArrayOf(0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U)
-
- val digest = Argon2Pure(
- password,
- salt,
- parallelism.toInt(),
- tagLength,
- memory,
- iterations,
- secret,
- associatedData,
- ArgonType.Argon2i
- )
- val result = digest.derive()
- result.hexColumsPrint(8)
- assertTrue { expected.contentEquals(result) }
-
- }
-
- @Test
- fun argon2idKATTest() {
- val expected : UByteArray = ubyteArrayOf(
- 0x0dU, 0x64U, 0x0dU, 0xf5U, 0x8dU, 0x78U, 0x76U, 0x6cU,
- 0x08U, 0xc0U, 0x37U, 0xa3U, 0x4aU, 0x8bU, 0x53U, 0xc9U,
- 0xd0U, 0x1eU, 0xf0U, 0x45U, 0x2dU, 0x75U, 0xb6U, 0x5eU,
- 0xb5U, 0x25U, 0x20U, 0xe9U, 0x6bU, 0x01U, 0xe6U, 0x59U
- )
-
-
- val memory = 32U //KiB
- val iterations = 3
- val parallelism = 4U
- val tagLength = 32U
- val password: UByteArray = ubyteArrayOf(
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U,
- 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U, 0x01U
- )
- val salt: UByteArray = ubyteArrayOf(0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U, 0x02U)
- val secret: UByteArray = ubyteArrayOf(0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U, 0x03U)
- val associatedData: UByteArray = ubyteArrayOf(0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U, 0x04U)
-
- val digest = Argon2Pure(
- password,
- salt,
- parallelism.toInt(),
- tagLength,
- memory,
- iterations,
- secret,
- associatedData,
- ArgonType.Argon2id
- )
- val result = digest.derive()
- result.hexColumsPrint(8)
- assertTrue { expected.contentEquals(result) }
-
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2MatrixTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2MatrixTest.kt
deleted file mode 100644
index ad69c98..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2MatrixTest.kt
+++ /dev/null
@@ -1,142 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_API_USAGE", "EXPERIMENTAL_UNSIGNED_LITERALS")
-
-package com.ionspin.kotlin.crypto.hash.argon
-
-import com.ionspin.kotlin.crypto.keyderivation.argon2.*
-import com.ionspin.kotlin.crypto.util.arrayChunked
-import com.ionspin.kotlin.crypto.util.fromLittleEndianArrayToULong
-import kotlin.random.Random
-import kotlin.random.nextUBytes
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-May-2020
- */
-class Argon2MatrixTest {
- val zeroesBlock = UByteArray(1024) { 0U }
- val onesBlock = UByteArray(1024) { 1U }
- val twosBlock = UByteArray(1024) { 2U }
- val threesBlock = UByteArray(1024) { 3U }
-
- val random = Random(1)
- val randomBlockArray = random.nextUBytes(1024)
-
-
- @Test
- fun indexAccessTest() {
- val argon2Matrix = ArgonMatrix(2, 2)
- (zeroesBlock + onesBlock + twosBlock + threesBlock).copyInto(argon2Matrix.storage)
- println(argon2Matrix[0, 0, 0])
- println(argon2Matrix[0, 1, 0])
- println(argon2Matrix[1, 0, 0])
- println(argon2Matrix[1, 1, 0])
-// argon2Matrix.storage.hexColumsPrint(1024)
- var expectedByteValue = 0U.toUByte()
- for (lane in 0 until 2) {
- for (column in 0 until 2) {
- for (blockPosition in 0 until 1024) {
- assertTrue {
- argon2Matrix[lane, column, blockPosition] == expectedByteValue
- }
- }
- expectedByteValue++
- }
- }
- assertTrue {
- argon2Matrix[0, 0, 0] == 0U.toUByte() &&
- argon2Matrix[0, 1, 0] == 1U.toUByte() &&
- argon2Matrix[1, 0, 0] == 2U.toUByte() &&
- argon2Matrix[1, 1, 0] == 3U.toUByte()
-
- }
- }
-
- @Test
- fun blockRetrievalTest() {
- val argon2Matrix = ArgonMatrix(2, 2)
- (zeroesBlock + onesBlock + twosBlock + threesBlock).copyInto(argon2Matrix.storage)
- assertTrue {
- zeroesBlock.contentEquals(argon2Matrix.getBlockAt(0, 0)) &&
- onesBlock.contentEquals(argon2Matrix.getBlockAt(0, 1)) &&
- twosBlock.contentEquals(argon2Matrix.getBlockAt(1, 0)) &&
- threesBlock.contentEquals(argon2Matrix.getBlockAt(1, 1))
- }
- }
-
- @Test
- fun blockColumnToUlongTest() {
- val randomBlock = ArgonBlock(randomBlockArray)
- for (columnIndex in 0 until 8) {
- val startOfRow = (columnIndex * 8 * 16)
- val endOfRow = startOfRow + (8 * 16)
- val rowToMix = randomBlockArray.copyOfRange(startOfRow, endOfRow)
- val expected = rowToMix.arrayChunked(8).map { it.fromLittleEndianArrayToULong() }.toULongArray()
-
- val result = randomBlock.getBlockPointer().getRowOfULongsForMixing(columnIndex)
-
- assertTrue { expected.contentEquals(result) }
- }
- }
-
- @Test
- fun blockRowToULongTest() {
- val randomBlock = ArgonBlock(randomBlockArray)
- for (rowIndex in 0 until 8) {
- val columnToMix = Argon2Utils.extractColumnFromGBlock(randomBlockArray, rowIndex)
- val expected = columnToMix.arrayChunked(8).map { it.fromLittleEndianArrayToULong() }.toULongArray()
- val result = randomBlock.getBlockPointer().getColumnOfULongsForMixing(rowIndex)
-
- assertTrue { expected.contentEquals(result) }
- }
- }
-
- @Test
- fun blockSetMixedRowTest() {
- val randomBlock = ArgonBlock(randomBlockArray)
- val targetBlockArray = zeroesBlock.copyOf()
- val targetBlock = ArgonBlock(targetBlockArray)
- for (rowIndex in 0 until 8) {
- val extracted = randomBlock.getBlockPointer().getRowOfULongsForMixing(rowIndex)
- targetBlock.getBlockPointer().setRowFromMixedULongs(rowIndex, extracted)
- }
-
- assertTrue {
- randomBlockArray.contentEquals(targetBlock.storage)
- }
- }
-
- @Test
- fun blockSetMixedColumnTest() {
- val randomBlock = ArgonBlock(randomBlockArray)
- val targetBlockArray = zeroesBlock.copyOf()
- val targetBlock = ArgonBlock(targetBlockArray)
- for (columnIndex in 0 until 8) {
- val extracted = randomBlock.getBlockPointer().getColumnOfULongsForMixing(columnIndex)
- targetBlock.getBlockPointer().setColumnFromMixedULongs(columnIndex, extracted)
- }
-
- assertTrue {
- randomBlockArray.contentEquals(targetBlock.storage)
- }
- }
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2Test.kt
deleted file mode 100644
index f513b7d..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/argon/Argon2Test.kt
+++ /dev/null
@@ -1,403 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-@file:Suppress("EXPERIMENTAL_API_USAGE", "EXPERIMENTAL_UNSIGNED_LITERALS")
-
-package com.ionspin.kotlin.crypto.hash.argon
-
-import com.ionspin.kotlin.crypto.keyderivation.argon2.Argon2Utils
-import com.ionspin.kotlin.crypto.keyderivation.argon2.ArgonBlock
-import com.ionspin.kotlin.crypto.util.fromLittleEndianArrayToULong
-import kotlin.random.Random
-import kotlin.random.nextUBytes
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-May-2020
- */
-class Argon2Test {
- val seededRandom = Random(1L)
- val randomBlockAsArray = seededRandom.nextUBytes(1024)
- val randomBlockAsArray2 = seededRandom.nextUBytes(1024)
- val randomBlockAsArray3 = seededRandom.nextUBytes(1024)
-
- @Test
- fun mixRoundTest() {
- val input = ubyteArrayOf(
- 0x00U, 0x01U, 0x02U, 0x03U, 0x04U, 0x05U, 0x06U, 0x07U,
- 0x08U, 0x09U, 0x0aU, 0x0bU, 0x0cU, 0x0dU, 0x0eU, 0x0fU,
- 0x10U, 0x11U, 0x12U, 0x13U, 0x14U, 0x15U, 0x16U, 0x17U,
- 0x18U, 0x19U, 0x1aU, 0x1bU, 0x1cU, 0x1dU, 0x1eU, 0x1fU,
- 0x20U, 0x21U, 0x22U, 0x23U, 0x24U, 0x25U, 0x26U, 0x27U,
- 0x28U, 0x29U, 0x2aU, 0x2bU, 0x2cU, 0x2dU, 0x2eU, 0x2fU,
- 0x30U, 0x31U, 0x32U, 0x33U, 0x34U, 0x35U, 0x36U, 0x37U,
- 0x38U, 0x39U, 0x3aU, 0x3bU, 0x3cU, 0x3dU, 0x3eU, 0x3fU,
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x57U,
- 0x58U, 0x59U, 0x5aU, 0x5bU, 0x5cU, 0x5dU, 0x5eU, 0x5fU,
- 0x60U, 0x61U, 0x62U, 0x63U, 0x64U, 0x65U, 0x66U, 0x67U,
- 0x68U, 0x69U, 0x6aU, 0x6bU, 0x6cU, 0x6dU, 0x6eU, 0x6fU,
- 0x70U, 0x71U, 0x72U, 0x73U, 0x74U, 0x75U, 0x76U, 0x77U,
- 0x78U, 0x79U, 0x7aU, 0x7bU, 0x7cU, 0x7dU, 0x7eU, 0x7fU
- )
-
- val expected = arrayOf(
- 16438755999881694465U,
- 2631578750119870528U,
- 8840261388583117524U,
- 13886387434724287670U,
- 14214935523062117944U,
- 6768869593113706780U,
- 12323449447979969623U,
- 7512951229622659062U,
- 9291745133539598579U,
- 11220895723773995914U,
- 2509429320847842905U,
- 5637172405908834370U,
- 8517838221434905893U,
- 14206719563334097702U,
- 6500029010075826286U,
- 16957672821843227543U
- )
- val preparedInput = input.chunked(8).map { it.toTypedArray().fromLittleEndianArrayToULong() }.toULongArray()
- val result = Argon2Utils.inplaceMixRound(preparedInput)
- assertTrue {
- expected.contentEquals(result.toTypedArray())
- }
-
- }
-
- @Test
- fun testExtractColumnFromGBlock() {
- val expected = ubyteArrayOf(
- 0x1AU, 0x2AU, 0xC5U, 0x23U, 0xB0U, 0x05U, 0xB1U, 0xA4U,
- 0x61U, 0x48U, 0x93U, 0xE0U, 0x6DU, 0x33U, 0xB6U, 0xA0U,
- 0x63U, 0x13U, 0xFFU, 0xEBU, 0x56U, 0x48U, 0xE7U, 0xD0U,
- 0x47U, 0x58U, 0x8EU, 0xD7U, 0xDEU, 0x01U, 0xCFU, 0x96U,
- 0xB4U, 0xE0U, 0x2AU, 0xF0U, 0x16U, 0x33U, 0x54U, 0xA9U,
- 0xF3U, 0xC3U, 0x98U, 0x2CU, 0xB7U, 0xECU, 0x1AU, 0x66U,
- 0xE0U, 0x6CU, 0xA5U, 0x66U, 0x73U, 0xE8U, 0x8AU, 0xF7U,
- 0x50U, 0x96U, 0xB8U, 0x16U, 0x47U, 0x41U, 0xA6U, 0x4CU,
- 0xAEU, 0x89U, 0xBAU, 0x5DU, 0x3CU, 0x49U, 0x33U, 0x23U,
- 0xD3U, 0xFBU, 0xD4U, 0x04U, 0x11U, 0x8FU, 0x98U, 0x10U,
- 0xDCU, 0xB7U, 0x06U, 0xE0U, 0x58U, 0xCFU, 0x48U, 0xE3U,
- 0x1FU, 0x33U, 0xE6U, 0x66U, 0x20U, 0xD2U, 0x34U, 0x43U,
- 0x62U, 0xA0U, 0x02U, 0x7FU, 0xE9U, 0x36U, 0xB3U, 0xB5U,
- 0x6BU, 0x07U, 0x8CU, 0xA7U, 0xB1U, 0x11U, 0x28U, 0x6FU,
- 0x6BU, 0xD0U, 0x09U, 0x4FU, 0xACU, 0x48U, 0x18U, 0xDCU,
- 0x70U, 0xB6U, 0xD6U, 0x27U, 0x69U, 0x50U, 0x97U, 0x87U,
- )
- val extracted = Argon2Utils.extractColumnFromGBlock(randomBlockAsArray, 0)
- assertTrue {
- expected.contentEquals(extracted)
- }
-
- }
-
- @Test
- fun testCompressionFunctionGWithoutXor() {
- val expectedWithoutXor = ubyteArrayOf(
- 0x94U, 0xE8U, 0x52U, 0x79U, 0xA7U, 0xE5U, 0x66U, 0xAAU,
- 0xD7U, 0xE1U, 0x8EU, 0x72U, 0x42U, 0xA2U, 0xE1U, 0x50U,
- 0x5FU, 0x77U, 0x7DU, 0xCDU, 0xE1U, 0xEFU, 0xAAU, 0xF5U,
- 0x29U, 0x94U, 0x29U, 0x17U, 0x9DU, 0x79U, 0xA5U, 0x67U,
- 0xD7U, 0x6CU, 0x11U, 0x18U, 0x6FU, 0xE0U, 0xA4U, 0x26U,
- 0xCCU, 0xF4U, 0xFDU, 0xD1U, 0xE0U, 0x42U, 0xC1U, 0x6AU,
- 0x33U, 0x99U, 0xC4U, 0x27U, 0x33U, 0x67U, 0xDDU, 0xC3U,
- 0x57U, 0x81U, 0xF5U, 0xCDU, 0x05U, 0x22U, 0x2DU, 0x5FU,
- 0x71U, 0x83U, 0xA9U, 0x54U, 0x1BU, 0x09U, 0x40U, 0x68U,
- 0x6DU, 0x78U, 0x0FU, 0x23U, 0xE2U, 0x90U, 0xC1U, 0x2DU,
- 0xBFU, 0x44U, 0x26U, 0xADU, 0x8BU, 0x77U, 0x0EU, 0xFBU,
- 0x9AU, 0x95U, 0x7AU, 0x8DU, 0xEAU, 0xCAU, 0xA2U, 0x1BU,
- 0xBDU, 0xC0U, 0x90U, 0x85U, 0x37U, 0xD9U, 0xF3U, 0x94U,
- 0x59U, 0x9EU, 0xB4U, 0xC4U, 0xBCU, 0xC1U, 0x47U, 0x31U,
- 0x66U, 0xE4U, 0x66U, 0x0EU, 0x86U, 0x11U, 0x4AU, 0x4CU,
- 0x36U, 0xA1U, 0x1CU, 0xDEU, 0xE9U, 0xA4U, 0x03U, 0x1FU,
- 0x9CU, 0x7AU, 0x1BU, 0x7AU, 0x8FU, 0x17U, 0xA3U, 0xD4U,
- 0x5BU, 0x23U, 0x8AU, 0x55U, 0x53U, 0x86U, 0x64U, 0xEDU,
- 0x24U, 0x97U, 0xFAU, 0x70U, 0xD4U, 0xF1U, 0x9AU, 0x10U,
- 0xBCU, 0x24U, 0x03U, 0xACU, 0x24U, 0x91U, 0x83U, 0xFBU,
- 0x66U, 0x02U, 0xC2U, 0x37U, 0xBEU, 0x63U, 0xCEU, 0x59U,
- 0xEAU, 0x02U, 0xAFU, 0x6CU, 0x8DU, 0x14U, 0xECU, 0xFDU,
- 0x5BU, 0x0AU, 0x0EU, 0xB6U, 0x51U, 0x2FU, 0x75U, 0xF1U,
- 0xA9U, 0x88U, 0xD1U, 0x05U, 0x60U, 0xE6U, 0xEDU, 0x17U,
- 0x4AU, 0x03U, 0x1FU, 0xF7U, 0x71U, 0x86U, 0x26U, 0x18U,
- 0x7EU, 0xB3U, 0x31U, 0x78U, 0xD8U, 0xB7U, 0x2CU, 0xD0U,
- 0x6DU, 0xB5U, 0xAEU, 0xDFU, 0x85U, 0xC6U, 0x87U, 0x9FU,
- 0x18U, 0x85U, 0x1BU, 0x22U, 0x19U, 0x15U, 0x00U, 0xF8U,
- 0x03U, 0xF7U, 0x48U, 0xA4U, 0xFCU, 0xE3U, 0xE4U, 0x93U,
- 0x02U, 0x57U, 0x71U, 0xBCU, 0xF6U, 0x2DU, 0x45U, 0xBEU,
- 0x87U, 0xC1U, 0x21U, 0x11U, 0x77U, 0x23U, 0x78U, 0xFCU,
- 0x56U, 0xBFU, 0x92U, 0x49U, 0xA1U, 0x51U, 0xE9U, 0x22U,
- 0x24U, 0x10U, 0x30U, 0x2EU, 0xE1U, 0xC1U, 0xF7U, 0x96U,
- 0xB0U, 0x27U, 0xF7U, 0x6CU, 0x65U, 0x0CU, 0x1BU, 0xE1U,
- 0xB2U, 0x12U, 0xD3U, 0xBCU, 0x8BU, 0xEDU, 0x9DU, 0x14U,
- 0x81U, 0x82U, 0xB3U, 0x5BU, 0x70U, 0x2CU, 0x65U, 0x54U,
- 0xF5U, 0x1FU, 0x1CU, 0x37U, 0xD2U, 0xD1U, 0x89U, 0x35U,
- 0x57U, 0x52U, 0xDDU, 0xA7U, 0x02U, 0x81U, 0x14U, 0xF7U,
- 0x6CU, 0x4CU, 0xB9U, 0x02U, 0x96U, 0x72U, 0xD2U, 0xFEU,
- 0x30U, 0x66U, 0x8CU, 0x16U, 0x50U, 0xB1U, 0x51U, 0xE9U,
- 0x48U, 0x48U, 0x83U, 0xA6U, 0x5CU, 0xF9U, 0x98U, 0x59U,
- 0xBAU, 0x2DU, 0xE5U, 0x73U, 0xADU, 0xD1U, 0x6AU, 0x7AU,
- 0x1FU, 0x6EU, 0xD8U, 0xC9U, 0xEDU, 0x00U, 0x9AU, 0xB1U,
- 0x34U, 0x08U, 0x0AU, 0x81U, 0x3EU, 0xCCU, 0x44U, 0xB7U,
- 0xD6U, 0xFEU, 0x0FU, 0x5CU, 0x19U, 0xD8U, 0x8FU, 0xEDU,
- 0x46U, 0x88U, 0xF5U, 0x5DU, 0x6BU, 0xDAU, 0x4DU, 0x02U,
- 0xA9U, 0xFCU, 0x67U, 0xBEU, 0x0CU, 0x09U, 0x38U, 0x98U,
- 0x79U, 0x52U, 0x7DU, 0xA6U, 0x24U, 0xA8U, 0x3BU, 0xB1U,
- 0xB2U, 0x52U, 0xC8U, 0x83U, 0x6CU, 0x02U, 0xD8U, 0xBDU,
- 0x7FU, 0x98U, 0xCCU, 0x65U, 0x01U, 0x90U, 0x6EU, 0x60U,
- 0xF8U, 0xB8U, 0x94U, 0xABU, 0x7BU, 0xA9U, 0x5FU, 0xE9U,
- 0xDAU, 0xCCU, 0x94U, 0x00U, 0xEDU, 0x8FU, 0x03U, 0xA3U,
- 0xCFU, 0xB3U, 0x14U, 0x38U, 0x94U, 0x91U, 0xF3U, 0x61U,
- 0xEBU, 0x04U, 0xDEU, 0x9DU, 0x9DU, 0x05U, 0x98U, 0xF3U,
- 0x71U, 0xB1U, 0xB3U, 0xB1U, 0x1DU, 0xA3U, 0x55U, 0x47U,
- 0xF4U, 0xA3U, 0xF8U, 0x7AU, 0x11U, 0xBBU, 0x0DU, 0x9CU,
- 0xB1U, 0x57U, 0xAAU, 0xC2U, 0x3CU, 0x0BU, 0xBEU, 0x77U,
- 0xBCU, 0x25U, 0x03U, 0x8BU, 0x7FU, 0x81U, 0xA5U, 0x7EU,
- 0xA9U, 0xB4U, 0x3FU, 0x5AU, 0x11U, 0x54U, 0x75U, 0x7DU,
- 0x45U, 0x20U, 0x90U, 0x46U, 0x98U, 0x70U, 0xF5U, 0x5BU,
- 0xA5U, 0x9DU, 0x46U, 0x63U, 0x62U, 0x3DU, 0x04U, 0x2FU,
- 0xB9U, 0x67U, 0x31U, 0xC5U, 0x92U, 0x48U, 0x18U, 0x0FU,
- 0xDCU, 0x52U, 0x78U, 0xCBU, 0x7CU, 0x86U, 0x58U, 0xDBU,
- 0x0BU, 0x06U, 0xF2U, 0x93U, 0x83U, 0x26U, 0x99U, 0x5DU,
- 0xBDU, 0xFBU, 0x87U, 0xC9U, 0x55U, 0x41U, 0xACU, 0x5FU,
- 0xA3U, 0xF9U, 0x71U, 0x53U, 0x93U, 0x53U, 0xC5U, 0xE4U,
- 0x3FU, 0x78U, 0x31U, 0x8FU, 0x7CU, 0x0BU, 0x77U, 0x84U,
- 0x43U, 0xACU, 0x4DU, 0xD1U, 0xC9U, 0x9BU, 0x4BU, 0x60U,
- 0x00U, 0xFEU, 0x41U, 0x10U, 0xEFU, 0xDFU, 0x80U, 0x95U,
- 0x03U, 0x23U, 0xBEU, 0xF6U, 0x6BU, 0x60U, 0xE5U, 0x6FU,
- 0x9EU, 0x6BU, 0x7CU, 0x24U, 0xA7U, 0xC1U, 0xF8U, 0xBBU,
- 0x60U, 0x55U, 0x57U, 0x18U, 0x58U, 0x32U, 0x97U, 0xE8U,
- 0x53U, 0x71U, 0x05U, 0x59U, 0xE3U, 0x94U, 0xB1U, 0x60U,
- 0x8AU, 0x40U, 0x24U, 0xF6U, 0x29U, 0x49U, 0x65U, 0xADU,
- 0x65U, 0xE3U, 0xCEU, 0x9FU, 0x4FU, 0x47U, 0xA0U, 0x07U,
- 0x2FU, 0x1CU, 0xA7U, 0x3AU, 0x04U, 0x17U, 0x87U, 0x1BU,
- 0x06U, 0xC5U, 0x93U, 0x63U, 0x3FU, 0x18U, 0x3BU, 0x8BU,
- 0x3EU, 0xD4U, 0xC0U, 0xC9U, 0x7EU, 0xB6U, 0x32U, 0xD3U,
- 0xC3U, 0x8BU, 0x55U, 0x2CU, 0x5BU, 0xB7U, 0xEBU, 0x88U,
- 0x14U, 0x63U, 0xB8U, 0x3BU, 0xDBU, 0xFFU, 0x49U, 0x44U,
- 0x79U, 0xD2U, 0x82U, 0xD8U, 0xA6U, 0x47U, 0x45U, 0xFBU,
- 0xF5U, 0x4BU, 0x5AU, 0x43U, 0x19U, 0xD9U, 0xD5U, 0x52U,
- 0x04U, 0x0CU, 0x4BU, 0x74U, 0x87U, 0x0DU, 0x11U, 0x8DU,
- 0x51U, 0x9DU, 0x66U, 0x68U, 0x41U, 0xE0U, 0xFCU, 0x92U,
- 0x24U, 0x7FU, 0x62U, 0xAFU, 0x8BU, 0x53U, 0xDEU, 0x84U,
- 0xF0U, 0xA1U, 0x03U, 0xAAU, 0x17U, 0x6FU, 0xD3U, 0x10U,
- 0x57U, 0x25U, 0xC6U, 0xA3U, 0x8FU, 0x1AU, 0xD3U, 0xD7U,
- 0x0DU, 0x89U, 0x22U, 0x3CU, 0x17U, 0xC6U, 0xF7U, 0x02U,
- 0x0CU, 0xD9U, 0x0FU, 0xABU, 0x27U, 0xA6U, 0xE3U, 0x20U,
- 0xF4U, 0xB2U, 0x21U, 0x12U, 0x85U, 0xF5U, 0x98U, 0x45U,
- 0x16U, 0x24U, 0xF7U, 0x46U, 0x5DU, 0x1FU, 0x41U, 0x9AU,
- 0x0EU, 0x25U, 0x4AU, 0x99U, 0x27U, 0x5CU, 0x0BU, 0xC8U,
- 0x33U, 0x99U, 0x65U, 0x3CU, 0xC9U, 0xDBU, 0x78U, 0x6DU,
- 0x36U, 0xC6U, 0x37U, 0x35U, 0x2EU, 0x97U, 0x04U, 0x03U,
- 0x26U, 0x78U, 0x5AU, 0x5AU, 0xD8U, 0xEAU, 0xF7U, 0xF1U,
- 0xF9U, 0x22U, 0x9DU, 0xDEU, 0xB7U, 0x50U, 0xFEU, 0x91U,
- 0xD4U, 0x5EU, 0xA1U, 0xC2U, 0x1BU, 0xE4U, 0x3FU, 0x19U,
- 0x50U, 0x21U, 0x1FU, 0x38U, 0xA1U, 0x11U, 0xB1U, 0x08U,
- 0x7DU, 0xA2U, 0xBBU, 0xE5U, 0xECU, 0x1BU, 0x9FU, 0x51U,
- 0x77U, 0x6CU, 0xB9U, 0xA8U, 0xC2U, 0x76U, 0xD4U, 0xCBU,
- 0x11U, 0x7DU, 0x4AU, 0x92U, 0xE2U, 0x0AU, 0x96U, 0x9AU,
- 0x28U, 0x72U, 0xFFU, 0xAAU, 0xF8U, 0xD5U, 0x64U, 0x8AU,
- 0x45U, 0x71U, 0xF3U, 0xB5U, 0xD7U, 0x2AU, 0x3BU, 0x7FU,
- 0x5CU, 0xFCU, 0x2DU, 0x89U, 0xBCU, 0x64U, 0x2FU, 0x63U,
- 0x87U, 0xE6U, 0x57U, 0xECU, 0x06U, 0xE3U, 0xDDU, 0x15U,
- 0xB4U, 0x27U, 0xA8U, 0x6CU, 0x37U, 0x54U, 0xD3U, 0x37U,
- 0xCFU, 0x4DU, 0x71U, 0x04U, 0x91U, 0x08U, 0x1AU, 0xC6U,
- 0xBDU, 0xEBU, 0x86U, 0xC5U, 0x5AU, 0x63U, 0x19U, 0xD5U,
- 0xC5U, 0xCBU, 0x82U, 0xC3U, 0x54U, 0x57U, 0xD8U, 0x6CU,
- 0x8FU, 0x9AU, 0xF1U, 0x7BU, 0x08U, 0x61U, 0xFCU, 0x96U,
- 0x1AU, 0xCEU, 0x8FU, 0x11U, 0xE2U, 0xDDU, 0x96U, 0xA3U,
- 0x57U, 0xD7U, 0x0DU, 0x28U, 0x06U, 0x0AU, 0xC5U, 0x1FU,
- 0xBBU, 0xC6U, 0x67U, 0xC8U, 0xB0U, 0xA7U, 0xDAU, 0x00U,
- 0xC3U, 0x00U, 0x21U, 0xACU, 0xFFU, 0xE9U, 0x4FU, 0xB7U,
- 0x9AU, 0xC9U, 0x77U, 0xC3U, 0x96U, 0x6EU, 0x1CU, 0xC4U,
- 0x61U, 0xAEU, 0x6FU, 0x55U, 0x0CU, 0xDAU, 0x68U, 0x48U,
- 0x97U, 0xEDU, 0x9CU, 0x90U, 0x17U, 0x2AU, 0x2DU, 0xC9U,
- 0x2AU, 0x77U, 0x87U, 0xECU, 0x64U, 0xF5U, 0x78U, 0x99U,
- 0xA9U, 0xB9U, 0x11U, 0x05U, 0xE9U, 0x7BU, 0x3BU, 0x49U,
- 0xAEU, 0x61U, 0x70U, 0x0BU, 0xBFU, 0xB7U, 0x67U, 0xA8U,
- 0x9FU, 0x02U, 0x30U, 0xD3U, 0x0BU, 0x14U, 0xF0U, 0x89U,
- 0x95U, 0x87U, 0x5BU, 0x04U, 0xF3U, 0x27U, 0xEFU, 0x91U,
- 0x4AU, 0xD4U, 0x7FU, 0x9EU, 0x73U, 0x95U, 0xE5U, 0x48U,
- 0x7FU, 0xE4U, 0xF6U, 0x92U, 0x85U, 0x47U, 0xA5U, 0xFEU,
- 0x12U, 0xD7U, 0xC4U, 0x9EU, 0xCFU, 0x8AU, 0xC2U, 0xD2U,
- 0x10U, 0x94U, 0xE5U, 0x58U, 0xBBU, 0xE0U, 0xEEU, 0xD9U,
- 0x6AU, 0x59U, 0xD9U, 0xBCU, 0xD5U, 0xCDU, 0xA0U, 0xBCU,
- 0xD7U, 0x96U, 0xAAU, 0x23U, 0xA9U, 0x10U, 0x6CU, 0x7EU,
-
- )
-
- val randomBlock1 = ArgonBlock(randomBlockAsArray).getBlockPointer()
- val randomBlock2 = ArgonBlock(randomBlockAsArray2).getBlockPointer()
- val randomBlock3 = ArgonBlock(randomBlockAsArray3).getBlockPointer()
- val resultWithoutXorAndAllocations = Argon2Utils.compressionFunctionG(randomBlock1, randomBlock2, randomBlock3, false)
- assertTrue {
- expectedWithoutXor.contentEquals(resultWithoutXorAndAllocations.getAsUByteArray())
- }
- }
-
- @Test
- fun compressionFunctionGWithXor() {
- val expectedWithXor = ubyteArrayOf(
-
- 0x44U, 0xD8U, 0x76U, 0x1AU, 0xD5U, 0x31U, 0xA5U, 0xEDU,
- 0xFAU, 0xABU, 0x43U, 0x60U, 0x21U, 0xB6U, 0x7DU, 0x28U,
- 0x65U, 0xF4U, 0xAFU, 0x07U, 0x1DU, 0x01U, 0xB4U, 0x50U,
- 0x85U, 0x3DU, 0x03U, 0x4CU, 0x33U, 0x58U, 0x8FU, 0xDCU,
- 0x10U, 0xDEU, 0x26U, 0xF4U, 0xEDU, 0x58U, 0xD1U, 0x84U,
- 0x7AU, 0x0AU, 0x05U, 0xC7U, 0x6BU, 0xA4U, 0xADU, 0x31U,
- 0x18U, 0x5DU, 0x11U, 0x10U, 0x5FU, 0x2FU, 0x5EU, 0x6CU,
- 0x3DU, 0x7EU, 0x3BU, 0xA8U, 0x92U, 0x61U, 0x80U, 0x84U,
- 0xD1U, 0x45U, 0x83U, 0x85U, 0xE6U, 0x14U, 0x4CU, 0x98U,
- 0x30U, 0xC1U, 0xB5U, 0x7FU, 0x50U, 0x56U, 0x71U, 0x43U,
- 0xEAU, 0x84U, 0x38U, 0x2AU, 0x42U, 0x95U, 0xF6U, 0x28U,
- 0x97U, 0x6BU, 0x86U, 0x6AU, 0x67U, 0x83U, 0xD1U, 0x87U,
- 0xA6U, 0x19U, 0x05U, 0x7AU, 0x11U, 0xA1U, 0x6EU, 0x10U,
- 0xCFU, 0x51U, 0x6CU, 0xE6U, 0x63U, 0x32U, 0x45U, 0xBCU,
- 0x6BU, 0x40U, 0xDBU, 0x8FU, 0x47U, 0x5BU, 0x4BU, 0x36U,
- 0x3CU, 0xB4U, 0xC8U, 0xF2U, 0x0AU, 0xE1U, 0xE1U, 0xFEU,
- 0x1FU, 0x8BU, 0xE4U, 0x36U, 0x75U, 0xEBU, 0x70U, 0x52U,
- 0x1DU, 0xE8U, 0xDEU, 0xD0U, 0xC4U, 0x7CU, 0x9CU, 0x33U,
- 0xC7U, 0x42U, 0x69U, 0x85U, 0x3FU, 0x99U, 0x75U, 0x59U,
- 0x9BU, 0xBEU, 0x02U, 0xC0U, 0xBEU, 0xC7U, 0x24U, 0xD0U,
- 0x66U, 0xD2U, 0x99U, 0xD5U, 0x43U, 0xECU, 0x8FU, 0xA2U,
- 0x17U, 0x10U, 0x56U, 0x1DU, 0x23U, 0xBAU, 0x33U, 0xF9U,
- 0x9AU, 0xEBU, 0x6BU, 0x0FU, 0x32U, 0x95U, 0x5BU, 0xB5U,
- 0x74U, 0x1DU, 0x22U, 0x36U, 0x1FU, 0x49U, 0xD6U, 0xC2U,
- 0xC0U, 0xEAU, 0xA1U, 0x07U, 0x73U, 0x9CU, 0x85U, 0x78U,
- 0xD6U, 0x63U, 0x98U, 0x44U, 0x7FU, 0x98U, 0x80U, 0x6BU,
- 0xC5U, 0x99U, 0x35U, 0xBCU, 0xB3U, 0xAAU, 0x8FU, 0xEBU,
- 0x32U, 0x62U, 0xAEU, 0xF7U, 0xAEU, 0x23U, 0x96U, 0xCBU,
- 0x58U, 0x84U, 0x50U, 0xA7U, 0x4CU, 0x85U, 0x7BU, 0xE3U,
- 0x32U, 0xE4U, 0xFAU, 0x66U, 0x25U, 0x60U, 0x64U, 0xA2U,
- 0x6FU, 0xE2U, 0x68U, 0xBDU, 0x61U, 0x5DU, 0x2CU, 0xD3U,
- 0x58U, 0xE2U, 0xC5U, 0x8CU, 0x42U, 0xC9U, 0x9CU, 0xECU,
- 0x62U, 0xE5U, 0xA9U, 0xC3U, 0x20U, 0x72U, 0x59U, 0x6AU,
- 0xF1U, 0xEAU, 0x54U, 0xEAU, 0xE6U, 0x80U, 0x09U, 0x8BU,
- 0x55U, 0x6CU, 0xDDU, 0x26U, 0x69U, 0xFDU, 0x25U, 0x97U,
- 0xDCU, 0xAFU, 0x1BU, 0x04U, 0x08U, 0xC2U, 0x54U, 0xBAU,
- 0xACU, 0xCBU, 0x97U, 0x7AU, 0xDBU, 0x59U, 0x8FU, 0x7DU,
- 0x95U, 0xB4U, 0x41U, 0x8AU, 0xC9U, 0xB4U, 0xF3U, 0xC0U,
- 0x5BU, 0x75U, 0x4EU, 0xE9U, 0x24U, 0x7FU, 0x8CU, 0xA1U,
- 0x05U, 0x6EU, 0x3BU, 0x3EU, 0xBDU, 0x03U, 0xE4U, 0x41U,
- 0x26U, 0x58U, 0x09U, 0xC1U, 0xE6U, 0x8EU, 0x22U, 0x59U,
- 0x3BU, 0xEEU, 0x21U, 0x5BU, 0x43U, 0x37U, 0x65U, 0xD2U,
- 0x13U, 0x6CU, 0xF8U, 0x06U, 0x48U, 0xADU, 0x09U, 0x9AU,
- 0xE1U, 0xE5U, 0x0CU, 0x2DU, 0x52U, 0xADU, 0x3BU, 0xC7U,
- 0xE7U, 0x78U, 0x7EU, 0xCDU, 0x1EU, 0xE9U, 0x7AU, 0x5DU,
- 0x54U, 0x89U, 0x1EU, 0xEFU, 0xA2U, 0x44U, 0xF4U, 0x38U,
- 0xE7U, 0xB5U, 0x0FU, 0xC8U, 0x1FU, 0x7EU, 0x9CU, 0x93U,
- 0x88U, 0x71U, 0xAEU, 0x19U, 0x0DU, 0x0FU, 0xCFU, 0xF1U,
- 0xCFU, 0x67U, 0x94U, 0x0FU, 0x5FU, 0xB2U, 0xC3U, 0x8FU,
- 0xE8U, 0xC3U, 0x07U, 0x0EU, 0xECU, 0x99U, 0x36U, 0x57U,
- 0x7AU, 0xA6U, 0xA9U, 0x44U, 0x5BU, 0x68U, 0x5AU, 0xB4U,
- 0xBFU, 0xA9U, 0xC9U, 0xE5U, 0xC8U, 0x20U, 0x31U, 0xD2U,
- 0xE9U, 0x3EU, 0x6FU, 0x09U, 0x8FU, 0x7DU, 0x75U, 0x0EU,
- 0x35U, 0xE8U, 0x90U, 0x04U, 0xB8U, 0x4AU, 0x12U, 0xE5U,
- 0xC0U, 0xCCU, 0x6AU, 0xB0U, 0x9FU, 0x8FU, 0xAFU, 0x8CU,
- 0x83U, 0x13U, 0x43U, 0x8EU, 0x5FU, 0x8AU, 0x1EU, 0xD3U,
- 0xF2U, 0x9AU, 0xE5U, 0x95U, 0x6DU, 0xAEU, 0x4DU, 0xDBU,
- 0x0CU, 0x06U, 0xDEU, 0x5CU, 0xD0U, 0x68U, 0xFFU, 0x4CU,
- 0xECU, 0x82U, 0xC8U, 0xAFU, 0x44U, 0xC0U, 0x3BU, 0x0BU,
- 0x89U, 0xADU, 0x32U, 0xAEU, 0xE7U, 0x36U, 0x2AU, 0x05U,
- 0x18U, 0x5FU, 0xB9U, 0xBDU, 0x52U, 0x7FU, 0x73U, 0x70U,
- 0x5AU, 0x5BU, 0x88U, 0x20U, 0x16U, 0x84U, 0xECU, 0x91U,
- 0xF7U, 0xD2U, 0x2FU, 0x6DU, 0x69U, 0x37U, 0xEAU, 0x2BU,
- 0x24U, 0xA2U, 0x58U, 0xDAU, 0x01U, 0x32U, 0x91U, 0x94U,
- 0x53U, 0x4DU, 0xBDU, 0x28U, 0xEAU, 0x70U, 0x75U, 0x77U,
- 0xD7U, 0x5DU, 0xF0U, 0xAAU, 0x5AU, 0x39U, 0xB9U, 0xC7U,
- 0xDBU, 0xC0U, 0xCFU, 0x72U, 0x6DU, 0xB0U, 0x04U, 0xBDU,
- 0x34U, 0x58U, 0x2AU, 0x6BU, 0x46U, 0xEDU, 0x7DU, 0x1AU,
- 0x15U, 0x85U, 0xD3U, 0x14U, 0xC6U, 0xF9U, 0x32U, 0x72U,
- 0x9AU, 0xD9U, 0x1AU, 0xBFU, 0xBDU, 0x3CU, 0x45U, 0x46U,
- 0x17U, 0x6DU, 0xAEU, 0x1EU, 0x12U, 0xE5U, 0x00U, 0x6DU,
- 0xD4U, 0xC0U, 0x71U, 0x8BU, 0xAFU, 0x12U, 0x7BU, 0x1EU,
- 0x73U, 0xD7U, 0x68U, 0x9EU, 0x45U, 0xC1U, 0x85U, 0xD9U,
- 0x15U, 0x6EU, 0xCAU, 0xCCU, 0x75U, 0x62U, 0x20U, 0x27U,
- 0x26U, 0x6AU, 0xFAU, 0x5FU, 0xB4U, 0x9FU, 0xDFU, 0x2EU,
- 0x3DU, 0x5BU, 0xE5U, 0x2BU, 0xEEU, 0x56U, 0x5CU, 0x91U,
- 0x28U, 0x56U, 0x7DU, 0x16U, 0x78U, 0x63U, 0xB5U, 0x3BU,
- 0x51U, 0xA3U, 0x96U, 0x52U, 0xDAU, 0x8EU, 0xBBU, 0x92U,
- 0xA0U, 0xD3U, 0xBDU, 0xB8U, 0xA1U, 0x4CU, 0x83U, 0xEDU,
- 0x4EU, 0x29U, 0xBEU, 0x9FU, 0x73U, 0x55U, 0x47U, 0x7AU,
- 0x31U, 0x30U, 0xFBU, 0x41U, 0x9DU, 0x89U, 0x26U, 0xF6U,
- 0x19U, 0x48U, 0x6CU, 0xB9U, 0xD0U, 0x11U, 0x8DU, 0xF8U,
- 0x8FU, 0x0FU, 0xB1U, 0x15U, 0x96U, 0xA9U, 0x06U, 0x4EU,
- 0x01U, 0xCCU, 0x48U, 0xBDU, 0x65U, 0x2FU, 0x27U, 0x67U,
- 0x74U, 0x89U, 0x54U, 0x24U, 0x88U, 0xF8U, 0x1EU, 0x90U,
- 0xFBU, 0xFFU, 0xD1U, 0x57U, 0xE2U, 0x95U, 0x97U, 0x2BU,
- 0x67U, 0x6EU, 0x6CU, 0xACU, 0x63U, 0x2CU, 0x96U, 0x61U,
- 0xBEU, 0x58U, 0xD8U, 0xE4U, 0x0FU, 0x94U, 0x27U, 0x4AU,
- 0x75U, 0x1CU, 0xE1U, 0x49U, 0xCDU, 0xFCU, 0x17U, 0xEAU,
- 0x68U, 0x0EU, 0x1AU, 0x86U, 0xFBU, 0xF6U, 0x27U, 0x87U,
- 0x48U, 0xBFU, 0x49U, 0x9AU, 0xB2U, 0x9EU, 0xAAU, 0xA9U,
- 0x7DU, 0x30U, 0x0AU, 0x21U, 0x16U, 0xD5U, 0x82U, 0x86U,
- 0x11U, 0x0EU, 0x9FU, 0xB0U, 0xC5U, 0x1CU, 0xBAU, 0xA7U,
- 0xB1U, 0x31U, 0x49U, 0x41U, 0x27U, 0x26U, 0xCEU, 0xDDU,
- 0xC4U, 0x45U, 0xA8U, 0xD5U, 0xC0U, 0x11U, 0xACU, 0xCCU,
- 0x9CU, 0x2EU, 0x04U, 0xB0U, 0xF8U, 0x87U, 0x29U, 0x8EU,
- 0x0FU, 0x53U, 0xF9U, 0xC9U, 0x69U, 0xFFU, 0x17U, 0x18U,
- 0x25U, 0x95U, 0x9EU, 0x88U, 0x03U, 0xC7U, 0xE9U, 0xC5U,
- 0xC6U, 0x2AU, 0xD0U, 0x91U, 0x7DU, 0x93U, 0xBDU, 0x77U,
- 0xB8U, 0xF1U, 0x5FU, 0x8CU, 0x83U, 0xE1U, 0x85U, 0x65U,
- 0x36U, 0xFAU, 0x43U, 0x90U, 0xBCU, 0x8EU, 0x12U, 0x1AU,
- 0xF0U, 0xF3U, 0x04U, 0x1FU, 0x77U, 0x6FU, 0xB8U, 0x52U,
- 0xFDU, 0xA3U, 0x6BU, 0x3DU, 0xFEU, 0xD8U, 0x86U, 0x14U,
- 0x10U, 0xFFU, 0xCFU, 0xF2U, 0xC7U, 0x06U, 0xE9U, 0x02U,
- 0x5CU, 0xFDU, 0x39U, 0xBBU, 0x3CU, 0x68U, 0xA2U, 0xBAU,
- 0x84U, 0x02U, 0xDAU, 0xD2U, 0x10U, 0x80U, 0xD6U, 0xCAU,
- 0xEAU, 0xDBU, 0xB9U, 0xAEU, 0xAEU, 0x85U, 0xBEU, 0xCDU,
- 0x72U, 0xCFU, 0xCFU, 0x6CU, 0xA0U, 0xFBU, 0x5CU, 0x74U,
- 0xADU, 0x4EU, 0x92U, 0x37U, 0xDBU, 0xD5U, 0x28U, 0x71U,
- 0x35U, 0xD0U, 0xACU, 0xE7U, 0x71U, 0xE1U, 0xB7U, 0x9AU,
- 0x2EU, 0x3FU, 0x8DU, 0xB8U, 0x10U, 0xC1U, 0xEEU, 0x35U,
- 0x0BU, 0x83U, 0xA3U, 0xF0U, 0xBAU, 0xFCU, 0x75U, 0x43U,
- 0x95U, 0x86U, 0x4CU, 0x0AU, 0x22U, 0xE8U, 0xDCU, 0x7DU,
- 0x6EU, 0xB8U, 0xF8U, 0xE2U, 0x97U, 0x57U, 0x06U, 0xB4U,
- 0x89U, 0xCAU, 0x9DU, 0xD5U, 0xDEU, 0xB6U, 0x48U, 0xCDU,
- 0x29U, 0x3CU, 0xDFU, 0x7EU, 0x1EU, 0x37U, 0xCEU, 0x48U,
- 0x20U, 0x5CU, 0xE3U, 0xCDU, 0x2FU, 0xA8U, 0xE5U, 0xC0U,
- 0xB7U, 0xABU, 0xDFU, 0xDBU, 0x8DU, 0xD8U, 0x5DU, 0xF7U,
- 0xA7U, 0x5CU, 0xF7U, 0xFFU, 0xD2U, 0x04U, 0xA5U, 0xE1U,
- 0x35U, 0xE3U, 0x67U, 0xCEU, 0x42U, 0xC1U, 0x3EU, 0xABU,
- 0x4AU, 0xFFU, 0x02U, 0x9AU, 0x94U, 0x9CU, 0x9AU, 0xC5U,
- 0xDCU, 0xC1U, 0x50U, 0x52U, 0x1CU, 0x04U, 0xF9U, 0x23U,
- 0x6DU, 0xA6U, 0x5AU, 0x9BU, 0xAAU, 0x5EU, 0x08U, 0xD1U,
- 0xCCU, 0x35U, 0x29U, 0xF5U, 0x3DU, 0xAAU, 0xB3U, 0x25U,
- 0xB6U, 0x07U, 0x29U, 0x4DU, 0x75U, 0x3CU, 0xADU, 0x17U,
- 0xBEU, 0xD5U, 0xC0U, 0xDFU, 0x05U, 0xFEU, 0xB8U, 0x2DU,
- 0x52U, 0xECU, 0xA7U, 0x67U, 0x6EU, 0xBAU, 0x32U, 0xE4U,
- 0xD6U, 0x31U, 0x13U, 0x83U, 0xFDU, 0xEBU, 0xEBU, 0x91U,
-
-
- )
-
- val randomBlock1 = ArgonBlock(randomBlockAsArray).getBlockPointer()
- val randomBlock2 = ArgonBlock(randomBlockAsArray2).getBlockPointer()
- val randomBlock3 = ArgonBlock(randomBlockAsArray3).getBlockPointer()
- val resultWithoutXorAndAllocations = Argon2Utils.compressionFunctionG(randomBlock1, randomBlock2, randomBlock3, true)
- assertTrue {
- expectedWithXor.contentEquals(resultWithoutXorAndAllocations.getAsUByteArray())
- }
- }
-
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2BTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2BTest.kt
deleted file mode 100644
index b90cbd6..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2BTest.kt
+++ /dev/null
@@ -1,295 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import kotlin.test.Test
-import kotlin.test.assertFailsWith
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jul-2019
- */
-
-
-class Blake2BTest {
-
- @Test
- fun testMultipleBlocks() {
- val test = "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890"
-
- val result = Blake2bPure.digest(test.encodeToUByteArray())
- //Generated with b2sum 8.31
- val expectedResult = ubyteArrayOf(
- //@formatter:off
- 0x2fU, 0x49U, 0xaeU, 0xb6U, 0x13U, 0xe3U, 0x4eU, 0x92U, 0x4eU, 0x17U, 0x5aU, 0x6aU, 0xf2U, 0xfaU, 0xadU,
- 0x7bU, 0xc7U, 0x82U, 0x35U, 0xf9U, 0xc5U, 0xe4U, 0x61U, 0xc6U, 0x8fU, 0xd5U, 0xb4U, 0x07U, 0xeeU, 0x8eU,
- 0x2fU, 0x0dU, 0x2fU, 0xb4U, 0xc0U, 0x7dU, 0x7eU, 0x4aU, 0x72U, 0x40U, 0x46U, 0x12U, 0xd9U, 0x28U, 0x99U,
- 0xafU, 0x8aU, 0x32U, 0x8fU, 0x3bU, 0x61U, 0x4eU, 0xd7U, 0x72U, 0x44U, 0xb4U, 0x81U, 0x15U, 0x1dU, 0x40U,
- 0xb1U, 0x1eU, 0x32U, 0xa4U
- //@formatter:on
- )
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-
- @Test
- fun singleBlockTest() {
- val test = "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890" +
- "1234567890"
-
-
- val result = Blake2bPure.digest(test.encodeToUByteArray())
- val expectedResultString = "800bb78cd4da18995c8074713bb674" +
- "3cd94b2b6490a693fe4000ed00833b88b7b474d94af9cfed246b1b" +
- "4ce1935a76154d7ea7c410493557741d18ec3a08da75"
- val expectedResult = expectedResultString.hexStringToUByteArray()
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-
-
- @Test
- fun testDigest() {
- val test = "111111111122222222223333333333333"
-
- val result = Blake2bPure.digest(test.encodeToUByteArray())
- //Generated with b2sum 8.31
- val expectedResult = ubyteArrayOf(
- //@formatter:off
- 0xe0U, 0xabU, 0xb7U, 0x5dU, 0xb2U, 0xc8U, 0xe1U, 0x3cU, 0x5fU, 0x1dU, 0x9fU, 0x55U, 0xc8U, 0x4eU, 0xacU, 0xd7U,
- 0xa8U, 0x44U, 0x57U, 0x9bU, 0xc6U, 0x9cU, 0x47U, 0x26U, 0xebU, 0xeaU, 0x2bU, 0xafU, 0x9eU, 0x44U, 0x16U, 0xebU,
- 0xb8U, 0x0aU, 0xc5U, 0xfbU, 0xb0U, 0xe8U, 0xe5U, 0x6eU, 0xc5U, 0x49U, 0x0dU, 0x75U, 0x59U, 0x32U, 0x13U, 0xb4U,
- 0x76U, 0x50U, 0x5eU, 0x6aU, 0xd8U, 0x74U, 0x67U, 0x14U, 0x64U, 0xb0U, 0xf8U, 0xb5U, 0x50U, 0x60U, 0x62U, 0xfbU
- //@formatter:on
- )
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
-
- }
-
- @Test
- fun testFigestWithKey() {
- val test = "abc"
- val key = "key"
-
- val result = Blake2bPure.digest(test.encodeToUByteArray(), key.encodeToUByteArray())
-
- assertTrue {
- result.isNotEmpty()
- }
- val expectedResult = ("5c6a9a4ae911c02fb7e71a991eb9aea371ae993d4842d206e" +
- "6020d46f5e41358c6d5c277c110ef86c959ed63e6ecaaaceaaff38019a43264ae06acf73b9550b1")
- .hexStringToUByteArray()
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-
-
- @Test
- fun testDigestFromRfc() {
- val test = "abc"
-
- val result = Blake2bPure.digest(test.encodeToUByteArray())
- //@formatter:off
- val expectedResult = ubyteArrayOf(
-
- 0xBAU,0x80U,0xA5U,0x3FU,0x98U,0x1CU,0x4DU,0x0DU,0x6AU,0x27U,0x97U,0xB6U,0x9FU,0x12U,0xF6U,0xE9U,
- 0x4CU,0x21U,0x2FU,0x14U,0x68U,0x5AU,0xC4U,0xB7U,0x4BU,0x12U,0xBBU,0x6FU,0xDBU,0xFFU,0xA2U,0xD1U,
- 0x7DU,0x87U,0xC5U,0x39U,0x2AU,0xABU,0x79U,0x2DU,0xC2U,0x52U,0xD5U,0xDEU,0x45U,0x33U,0xCCU,0x95U,
- 0x18U,0xD3U,0x8AU,0xA8U,0xDBU,0xF1U,0x92U,0x5AU,0xB9U,0x23U,0x86U,0xEDU,0xD4U,0x00U,0x99U,0x23U
-
- )
- //@formatter:on
- assertTrue {
- result.contentEquals(expectedResult)
- }
-
- }
-
- val message = arrayOf(
- 0x0000000000636261UL, 0x0000000000000000UL, 0x0000000000000000UL,
- 0x0000000000000000UL, 0x0000000000000000UL, 0x0000000000000000UL,
- 0x0000000000000000UL, 0x0000000000000000UL, 0x0000000000000000UL,
- 0x0000000000000000UL, 0x0000000000000000UL, 0x0000000000000000UL,
- 0x0000000000000000UL, 0x0000000000000000UL, 0x0000000000000000UL,
- 0x0000000000000000UL
- )
-
- val mixChain = arrayOf(
- arrayOf(
- 0x6A09E667F2BDC948UL, 0xBB67AE8584CAA73BUL, 0x3C6EF372FE94F82BUL,
- 0xA54FF53A5F1D36F1UL, 0x510E527FADE682D1UL, 0x9B05688C2B3E6C1FUL,
- 0x1F83D9ABFB41BD6BUL, 0x5BE0CD19137E2179UL, 0x6A09E667F3BCC908UL,
- 0xBB67AE8584CAA73BUL, 0x3C6EF372FE94F82BUL, 0xA54FF53A5F1D36F1UL,
- 0x510E527FADE682D2UL, 0x9B05688C2B3E6C1FUL, 0xE07C265404BE4294UL,
- 0x5BE0CD19137E2179UL
- ),
- arrayOf(
- 0x86B7C1568029BB79UL, 0xC12CBCC809FF59F3UL, 0xC6A5214CC0EACA8EUL,
- 0x0C87CD524C14CC5DUL, 0x44EE6039BD86A9F7UL, 0xA447C850AA694A7EUL,
- 0xDE080F1BB1C0F84BUL, 0x595CB8A9A1ACA66CUL, 0xBEC3AE837EAC4887UL,
- 0x6267FC79DF9D6AD1UL, 0xFA87B01273FA6DBEUL, 0x521A715C63E08D8AUL,
- 0xE02D0975B8D37A83UL, 0x1C7B754F08B7D193UL, 0x8F885A76B6E578FEUL,
- 0x2318A24E2140FC64UL
- ),
- arrayOf(
- 0x53281E83806010F2UL, 0x3594B403F81B4393UL, 0x8CD63C7462DE0DFFUL,
- 0x85F693F3DA53F974UL, 0xBAABDBB2F386D9AEUL, 0xCA5425AEC65A10A8UL,
- 0xC6A22E2FF0F7AA48UL, 0xC6A56A51CB89C595UL, 0x224E6A3369224F96UL,
- 0x500E125E58A92923UL, 0xE9E4AD0D0E1A0D48UL, 0x85DF9DC143C59A74UL,
- 0x92A3AAAA6D952B7FUL, 0xC5FDF71090FAE853UL, 0x2A8A40F15A462DD0UL,
- 0x572D17EFFDD37358UL
- ),
- arrayOf(
- 0x60ED96AA7AD41725UL, 0xE46A743C71800B9DUL, 0x1A04B543A01F156BUL,
- 0xA2F8716E775C4877UL, 0xDA0A61BCDE4267EAUL, 0xB1DD230754D7BDEEUL,
- 0x25A1422779E06D14UL, 0xE6823AE4C3FF58A5UL, 0xA1677E19F37FD5DAUL,
- 0x22BDCE6976B08C51UL, 0xF1DE8696BEC11BF1UL, 0xA0EBD586A4A1D2C8UL,
- 0xC804EBAB11C99FA9UL, 0x8E0CEC959C715793UL, 0x7C45557FAE0D4D89UL,
- 0x716343F52FDD265EUL
- ),
- arrayOf(
- 0xBB2A77D3A8382351UL, 0x45EB47971F23B103UL, 0x98BE297F6E45C684UL,
- 0xA36077DEE3370B89UL, 0x8A03C4CB7E97590AUL, 0x24192E49EBF54EA0UL,
- 0x4F82C9401CB32D7AUL, 0x8CCD013726420DC4UL, 0xA9C9A8F17B1FC614UL,
- 0x55908187977514A0UL, 0x5B44273E66B19D27UL, 0xB6D5C9FCA2579327UL,
- 0x086092CFB858437EUL, 0x5C4BE2156DBEECF9UL, 0x2EFEDE99ED4EFF16UL,
- 0x3E7B5F234CD1F804UL
- ),
- arrayOf(
- 0xC79C15B3D423B099UL, 0x2DA2224E8DA97556UL, 0x77D2B26DF1C45C55UL,
- 0x8934EB09A3456052UL, 0x0F6D9EEED157DA2AUL, 0x6FE66467AF88C0A9UL,
- 0x4EB0B76284C7AAFBUL, 0x299C8E725D954697UL, 0xB2240B59E6D567D3UL,
- 0x2643C2370E49EBFDUL, 0x79E02EEF20CDB1AEUL, 0x64B3EED7BB602F39UL,
- 0xB97D2D439E4DF63DUL, 0xC718E755294C9111UL, 0x1F0893F2772BB373UL,
- 0x1205EA4A7859807DUL
- ),
- arrayOf(
- 0xE58F97D6385BAEE4UL, 0x7640AA9764DA137AUL, 0xDEB4C7C23EFE287EUL,
- 0x70F6F41C8783C9F6UL, 0x7127CD48C76A7708UL, 0x9E472AF0BE3DB3F6UL,
- 0x0F244C62DDF71788UL, 0x219828AA83880842UL, 0x41CCA9073C8C4D0DUL,
- 0x5C7912BC10DF3B4BUL, 0xA2C3ABBD37510EE2UL, 0xCB5668CC2A9F7859UL,
- 0x8733794F07AC1500UL, 0xC67A6BE42335AA6FUL, 0xACB22B28681E4C82UL,
- 0xDB2161604CBC9828UL
- ),
- arrayOf(
- 0x6E2D286EEADEDC81UL, 0xBCF02C0787E86358UL, 0x57D56A56DD015EDFUL,
- 0x55D899D40A5D0D0AUL, 0x819415B56220C459UL, 0xB63C479A6A769F02UL,
- 0x258E55E0EC1F362AUL, 0x3A3B4EC60E19DFDCUL, 0x04D769B3FCB048DBUL,
- 0xB78A9A33E9BFF4DDUL, 0x5777272AE1E930C0UL, 0x5A387849E578DBF6UL,
- 0x92AAC307CF2C0AFCUL, 0x30AACCC4F06DAFAAUL, 0x483893CC094F8863UL,
- 0xE03C6CC89C26BF92UL
- ),
- arrayOf(
- 0xFFC83ECE76024D01UL, 0x1BE7BFFB8C5CC5F9UL, 0xA35A18CBAC4C65B7UL,
- 0xB7C2C7E6D88C285FUL, 0x81937DA314A50838UL, 0xE1179523A2541963UL,
- 0x3A1FAD7106232B8FUL, 0x1C7EDE92AB8B9C46UL, 0xA3C2D35E4F685C10UL,
- 0xA53D3F73AA619624UL, 0x30BBCC0285A22F65UL, 0xBCEFBB6A81539E5DUL,
- 0x3841DEF6F4C9848AUL, 0x98662C85FBA726D4UL, 0x7762439BD5A851BDUL,
- 0xB0B9F0D443D1A889UL
- ),
- arrayOf(
- 0x753A70A1E8FAEADDUL, 0x6B0D43CA2C25D629UL, 0xF8343BA8B94F8C0BUL,
- 0xBC7D062B0DB5CF35UL, 0x58540EE1B1AEBC47UL, 0x63C5B9B80D294CB9UL,
- 0x490870ECAD27DEBDUL, 0xB2A90DDF667287FEUL, 0x316CC9EBEEFAD8FCUL,
- 0x4A466BCD021526A4UL, 0x5DA7F7638CEC5669UL, 0xD9C8826727D306FCUL,
- 0x88ED6C4F3BD7A537UL, 0x19AE688DDF67F026UL, 0x4D8707AAB40F7E6DUL,
- 0xFD3F572687FEA4F1UL
- ),
- arrayOf(
- 0xE630C747CCD59C4FUL, 0xBC713D41127571CAUL, 0x46DB183025025078UL,
- 0x6727E81260610140UL, 0x2D04185EAC2A8CBAUL, 0x5F311B88904056ECUL,
- 0x40BD313009201AABUL, 0x0099D4F82A2A1EABUL, 0x6DD4FBC1DE60165DUL,
- 0xB3B0B51DE3C86270UL, 0x900AEE2F233B08E5UL, 0xA07199D87AD058D8UL,
- 0x2C6B25593D717852UL, 0x37E8CA471BEAA5F8UL, 0x2CFC1BAC10EF4457UL,
- 0x01369EC18746E775UL
- ),
- arrayOf(
- 0xE801F73B9768C760UL, 0x35C6D22320BE511DUL, 0x306F27584F65495EUL,
- 0xB51776ADF569A77BUL, 0xF4F1BE86690B3C34UL, 0x3CC88735D1475E4BUL,
- 0x5DAC67921FF76949UL, 0x1CDB9D31AD70CC4EUL, 0x35BA354A9C7DF448UL,
- 0x4929CBE45679D73EUL, 0x733D1A17248F39DBUL, 0x92D57B736F5F170AUL,
- 0x61B5C0A41D491399UL, 0xB5C333457E12844AUL, 0xBD696BE010D0D889UL,
- 0x02231E1A917FE0BDUL
- ),
- arrayOf(
- 0x12EF8A641EC4F6D6UL, 0xBCED5DE977C9FAF5UL, 0x733CA476C5148639UL,
- 0x97DF596B0610F6FCUL, 0xF42C16519AD5AFA7UL, 0xAA5AC1888E10467EUL,
- 0x217D930AA51787F3UL, 0x906A6FF19E573942UL, 0x75AB709BD3DCBF24UL,
- 0xEE7CE1F345947AA4UL, 0xF8960D6C2FAF5F5EUL, 0xE332538A36B6D246UL,
- 0x885BEF040EF6AA0BUL, 0xA4939A417BFB78A3UL, 0x646CBB7AF6DCE980UL,
- 0xE813A23C60AF3B82UL
- )
- )
-
- @Test
- fun testMixRound() {
- for (i in 0 until mixChain.size - 1) {
- val inputRound = mixChain[i]
- val round = i
- val result = Blake2bPure.mixRound(inputRound, message, round)
- val expectedResult = mixChain[i + 1]
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-
-
- }
-
- @Test
- fun testInvalidHashLength() {
- val test = "1234567890"
- assertFailsWith(RuntimeException::class) {
- val result = Blake2bPure.digest(test.encodeToUByteArray(), hashLength = 65)
- }
- }
-
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bInstanceTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bInstanceTest.kt
deleted file mode 100644
index 68cb23e..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bInstanceTest.kt
+++ /dev/null
@@ -1,94 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 20-Jul-2019
- */
-
-
-class Blake2bInstanceTest {
-
- @Test
- fun testUpdatableBlake2b() {
- val updates = 14
- val input = "1234567890"
- val expectedResult = ubyteArrayOf(
- //@formatter:off
- 0x2fU, 0x49U, 0xaeU, 0xb6U, 0x13U, 0xe3U, 0x4eU, 0x92U, 0x4eU, 0x17U, 0x5aU, 0x6aU, 0xf2U, 0xfaU, 0xadU,
- 0x7bU, 0xc7U, 0x82U, 0x35U, 0xf9U, 0xc5U, 0xe4U, 0x61U, 0xc6U, 0x8fU, 0xd5U, 0xb4U, 0x07U, 0xeeU, 0x8eU,
- 0x2fU, 0x0dU, 0x2fU, 0xb4U, 0xc0U, 0x7dU, 0x7eU, 0x4aU, 0x72U, 0x40U, 0x46U, 0x12U, 0xd9U, 0x28U, 0x99U,
- 0xafU, 0x8aU, 0x32U, 0x8fU, 0x3bU, 0x61U, 0x4eU, 0xd7U, 0x72U, 0x44U, 0xb4U, 0x81U, 0x15U, 0x1dU, 0x40U,
- 0xb1U, 0x1eU, 0x32U, 0xa4U
- //@formatter:on
- )
-
- val blake2b = Blake2bPure()
- for (i in 0 until updates) {
- blake2b.update(input)
- }
- val result = blake2b.digest()
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-
- @Test
- fun testDigestToString() {
- val updates = 14
- val input = "1234567890"
- val expectedResult = "2F49AEB613E34E924E175A6AF2FAAD7BC78235F9C5E461C68FD5B407E".toLowerCase() +
- "E8E2F0D2FB4C07D7E4A72404612D92899AF8A328F3B614ED77244B481151D40B11E32A4".toLowerCase()
-
- val blake2b = Blake2bPure()
- for (i in 0 until updates) {
- blake2b.update(input)
- }
- val result = blake2b.digest().toHexString()
- assertTrue {
- result == expectedResult
- }
- }
-
- @Test
- fun testDigestWithKey() {
- val test = "abc"
- val key = "key"
- val blake2b = Blake2bPure(key)
- blake2b.update(test)
- val result = blake2b.digest()
-
- assertTrue {
- result.isNotEmpty()
- }
- val expectedResult = ("5c6a9a4ae911c02fb7e71a991eb9aea371ae993d4842d206e" +
- "6020d46f5e41358c6d5c277c110ef86c959ed63e6ecaaaceaaff38019a43264ae06acf73b9550b1")
- .hexStringToUByteArray()
-
- assertTrue {
- result.contentEquals(expectedResult)
- }
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bKnowAnswerTests.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bKnowAnswerTests.kt
deleted file mode 100644
index 21fb963..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/blake2b/Blake2bKnowAnswerTests.kt
+++ /dev/null
@@ -1,1603 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.blake2b
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 15-Jul-2019
- */
-data class KnownAnswerTest(
- val input: String,
- val key: String,
- val hash: String
-)
-
-
-
-class Blake2bKnowAnswerTests {
- @Test
- fun knownAnswerTest() {
- kat.forEach {
- val parsedInput = it.input.hexStringToUByteArray()
- val result = Blake2bPure.digest(
- inputMessage = parsedInput,
- key = it.key.hexStringToUByteArray()
- )
- assertTrue {
- result.contentEquals(it.hash.hexStringToUByteArray())
- }
- }
- }
-
- @Test
- fun knownAnswerTestInstance() {
-
- kat.forEach { kat ->
- val parsedInput = kat.input.hexStringToUByteArray()
- val chunkedInput = parsedInput.toList().chunked(128).map { it.toUByteArray() }
- val blake2b = Blake2bPure(key = kat.key.hexStringToUByteArray())
- chunkedInput.forEach { blake2b.update(it) }
- val result = blake2b.digest()
- assertTrue("KAT ${kat.input} \nkey: ${kat.key} \nexpected: {${kat.hash}") {
- result.contentEquals(kat.hash.hexStringToUByteArray())
- }
- }
- }
-
- val kat = arrayOf(
- KnownAnswerTest(
- input = "",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "10ebb67700b1868efb4417987acf4690ae9d972fb7a590c2f02871799aaa4786b5e996e8f0f4eb981fc214b005f42d2ff4233499391653df7aefcbc13fc51568"
- ),
-
- KnownAnswerTest(
- input = "00",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "961f6dd1e4dd30f63901690c512e78e4b45e4742ed197c3c5e45c549fd25f2e4187b0bc9fe30492b16b0d0bc4ef9b0f34c7003fac09a5ef1532e69430234cebd"
- ),
-
- KnownAnswerTest(
- input = "0001",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "da2cfbe2d8409a0f38026113884f84b50156371ae304c4430173d08a99d9fb1b983164a3770706d537f49e0c916d9f32b95cc37a95b99d857436f0232c88a965"
- ),
-
- KnownAnswerTest(
- input = "000102",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "33d0825dddf7ada99b0e7e307104ad07ca9cfd9692214f1561356315e784f3e5a17e364ae9dbb14cb2036df932b77f4b292761365fb328de7afdc6d8998f5fc1"
- ),
-
- KnownAnswerTest(
- input = "00010203",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "beaa5a3d08f3807143cf621d95cd690514d0b49efff9c91d24b59241ec0eefa5f60196d407048bba8d2146828ebcb0488d8842fd56bb4f6df8e19c4b4daab8ac"
- ),
-
- KnownAnswerTest(
- input = "0001020304",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "098084b51fd13deae5f4320de94a688ee07baea2800486689a8636117b46c1f4c1f6af7f74ae7c857600456a58a3af251dc4723a64cc7c0a5ab6d9cac91c20bb"
- ),
-
- KnownAnswerTest(
- input = "000102030405",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "6044540d560853eb1c57df0077dd381094781cdb9073e5b1b3d3f6c7829e12066bbaca96d989a690de72ca3133a83652ba284a6d62942b271ffa2620c9e75b1f"
- ),
-
- KnownAnswerTest(
- input = "00010203040506",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7a8cfe9b90f75f7ecb3acc053aaed6193112b6f6a4aeeb3f65d3de541942deb9e2228152a3c4bbbe72fc3b12629528cfbb09fe630f0474339f54abf453e2ed52"
- ),
-
- KnownAnswerTest(
- input = "0001020304050607",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "380beaf6ea7cc9365e270ef0e6f3a64fb902acae51dd5512f84259ad2c91f4bc4108db73192a5bbfb0cbcf71e46c3e21aee1c5e860dc96e8eb0b7b8426e6abe9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "60fe3c4535e1b59d9a61ea8500bfac41a69dffb1ceadd9aca323e9a625b64da5763bad7226da02b9c8c4f1a5de140ac5a6c1124e4f718ce0b28ea47393aa6637"
- ),
-
- KnownAnswerTest(
- input = "00010203040506070809",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "4fe181f54ad63a2983feaaf77d1e7235c2beb17fa328b6d9505bda327df19fc37f02c4b6f0368ce23147313a8e5738b5fa2a95b29de1c7f8264eb77b69f585cd"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f228773ce3f3a42b5f144d63237a72d99693adb8837d0e112a8a0f8ffff2c362857ac49c11ec740d1500749dac9b1f4548108bf3155794dcc9e4082849e2b85b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "962452a8455cc56c8511317e3b1f3b2c37df75f588e94325fdd77070359cf63a9ae6e930936fdf8e1e08ffca440cfb72c28f06d89a2151d1c46cd5b268ef8563"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "43d44bfa18768c59896bf7ed1765cb2d14af8c260266039099b25a603e4ddc5039d6ef3a91847d1088d401c0c7e847781a8a590d33a3c6cb4df0fab1c2f22355"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "dcffa9d58c2a4ca2cdbb0c7aa4c4c1d45165190089f4e983bb1c2cab4aaeff1fa2b5ee516fecd780540240bf37e56c8bcca7fab980e1e61c9400d8a9a5b14ac6"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "6fbf31b45ab0c0b8dad1c0f5f4061379912dde5aa922099a030b725c73346c524291adef89d2f6fd8dfcda6d07dad811a9314536c2915ed45da34947e83de34e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "a0c65bddde8adef57282b04b11e7bc8aab105b99231b750c021f4a735cb1bcfab87553bba3abb0c3e64a0b6955285185a0bd35fb8cfde557329bebb1f629ee93"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f10",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f99d815550558e81eca2f96718aed10d86f3f1cfb675cce06b0eff02f617c5a42c5aa760270f2679da2677c5aeb94f1142277f21c7f79f3c4f0cce4ed8ee62b1"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f1011",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "95391da8fc7b917a2044b3d6f5374e1ca072b41454d572c7356c05fd4bc1e0f40b8bb8b4a9f6bce9be2c4623c399b0dca0dab05cb7281b71a21b0ebcd9e55670"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "04b9cd3d20d221c09ac86913d3dc63041989a9a1e694f1e639a3ba7e451840f750c2fc191d56ad61f2e7936bc0ac8e094b60caeed878c18799045402d61ceaf9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f10111213",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ec0e0ef707e4ed6c0c66f9e089e4954b058030d2dd86398fe84059631f9ee591d9d77375355149178c0cf8f8e7c49ed2a5e4f95488a2247067c208510fadc44c"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f1011121314",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "9a37cce273b79c09913677510eaf7688e89b3314d3532fd2764c39de022a2945b5710d13517af8ddc0316624e73bec1ce67df15228302036f330ab0cb4d218dd"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "4cf9bb8fb3d4de8b38b2f262d3c40f46dfe747e8fc0a414c193d9fcf753106ce47a18f172f12e8a2f1c26726545358e5ee28c9e2213a8787aafbc516d2343152"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f10111213141516",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "64e0c63af9c808fd893137129867fd91939d53f2af04be4fa268006100069b2d69daa5c5d8ed7fddcb2a70eeecdf2b105dd46a1e3b7311728f639ab489326bc9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f1011121314151617",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5e9c93158d659b2def06b0c3c7565045542662d6eee8a96a89b78ade09fe8b3dcc096d4fe48815d88d8f82620156602af541955e1f6ca30dce14e254c326b88f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7775dff889458dd11aef417276853e21335eb88e4dec9cfb4e9edb49820088551a2ca60339f12066101169f0dfe84b098fddb148d9da6b3d613df263889ad64b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f10111213141516171819",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f0d2805afbb91f743951351a6d024f9353a23c7ce1fc2b051b3a8b968c233f46f50f806ecb1568ffaa0b60661e334b21dde04f8fa155ac740eeb42e20b60d764"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "86a2af316e7d7754201b942e275364ac12ea8962ab5bd8d7fb276dc5fbffc8f9a28cae4e4867df6780d9b72524160927c855da5b6078e0b554aa91e31cb9ca1d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "10bdf0caa0802705e706369baf8a3f79d72c0a03a80675a7bbb00be3a45e516424d1ee88efb56f6d5777545ae6e27765c3a8f5e493fc308915638933a1dfee55"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b01781092b1748459e2e4ec178696627bf4ebafebba774ecf018b79a68aeb84917bf0b84bb79d17b743151144cd66b7b33a4b9e52c76c4e112050ff5385b7f0b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c6dbc61dec6eaeac81e3d5f755203c8e220551534a0b2fd105a91889945a638550204f44093dd998c076205dffad703a0e5cd3c7f438a7e634cd59fededb539e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "eba51acffb4cea31db4b8d87e9bf7dd48fe97b0253ae67aa580f9ac4a9d941f2bea518ee286818cc9f633f2a3b9fb68e594b48cdd6d515bf1d52ba6c85a203a7"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "86221f3ada52037b72224f105d7999231c5e5534d03da9d9c0a12acb68460cd375daf8e24386286f9668f72326dbf99ba094392437d398e95bb8161d717f8991"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5595e05c13a7ec4dc8f41fb70cb50a71bce17c024ff6de7af618d0cc4e9c32d9570d6d3ea45b86525491030c0d8f2b1836d5778c1ce735c17707df364d054347"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f2021",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ce0f4f6aca89590a37fe034dd74dd5fa65eb1cbd0a41508aaddc09351a3cea6d18cb2189c54b700c009f4cbf0521c7ea01be61c5ae09cb54f27bc1b44d658c82"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7ee80b06a215a3bca970c77cda8761822bc103d44fa4b33f4d07dcb997e36d55298bceae12241b3fa07fa63be5576068da387b8d5859aeab701369848b176d42"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20212223",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "940a84b6a84d109aab208c024c6ce9647676ba0aaa11f86dbb7018f9fd2220a6d901a9027f9abcf935372727cbf09ebd61a2a2eeb87653e8ecad1bab85dc8327"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f2021222324",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "2020b78264a82d9f4151141adba8d44bf20c5ec062eee9b595a11f9e84901bf148f298e0c9f8777dcdbc7cc4670aac356cc2ad8ccb1629f16f6a76bcefbee760"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d1b897b0e075ba68ab572adf9d9c436663e43eb3d8e62d92fc49c9be214e6f27873fe215a65170e6bea902408a25b49506f47babd07cecf7113ec10c5dd31252"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20212223242526",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b14d0c62abfa469a357177e594c10c194243ed2025ab8aa5ad2fa41ad318e0ff48cd5e60bec07b13634a711d2326e488a985f31e31153399e73088efc86a5c55"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f2021222324252627",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "4169c5cc808d2697dc2a82430dc23e3cd356dc70a94566810502b8d655b39abf9e7f902fe717e0389219859e1945df1af6ada42e4ccda55a197b7100a30c30a1"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "258a4edb113d66c839c8b1c91f15f35ade609f11cd7f8681a4045b9fef7b0b24c82cda06a5f2067b368825e3914e53d6948ede92efd6e8387fa2e537239b5bee"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f20212223242526272829",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "79d2d8696d30f30fb34657761171a11e6c3f1e64cbe7bebee159cb95bfaf812b4f411e2f26d9c421dc2c284a3342d823ec293849e42d1e46b0a4ac1e3c86abaa"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8b9436010dc5dee992ae38aea97f2cd63b946d94fedd2ec9671dcde3bd4ce9564d555c66c15bb2b900df72edb6b891ebcadfeff63c9ea4036a998be7973981e7"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c8f68e696ed28242bf997f5b3b34959508e42d613810f1e2a435c96ed2ff560c7022f361a9234b9837feee90bf47922ee0fd5f8ddf823718d86d1e16c6090071"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b02d3eee4860d5868b2c39ce39bfe81011290564dd678c85e8783f29302dfc1399ba95b6b53cd9ebbf400cca1db0ab67e19a325f2d115812d25d00978ad1bca4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7693ea73af3ac4dad21ca0d8da85b3118a7d1c6024cfaf557699868217bc0c2f44a199bc6c0edd519798ba05bd5b1b4484346a47c2cadf6bf30b785cc88b2baf"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "a0e5c1c0031c02e48b7f09a5e896ee9aef2f17fc9e18e997d7f6cac7ae316422c2b1e77984e5f3a73cb45deed5d3f84600105e6ee38f2d090c7d0442ea34c46d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "41daa6adcfdb69f1440c37b596440165c15ada596813e2e22f060fcd551f24dee8e04ba6890387886ceec4a7a0d7fc6b44506392ec3822c0d8c1acfc7d5aebe8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f30",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "14d4d40d5984d84c5cf7523b7798b254e275a3a8cc0a1bd06ebc0bee726856acc3cbf516ff667cda2058ad5c3412254460a82c92187041363cc77a4dc215e487"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d0e7a1e2b9a447fee83e2277e9ff8010c2f375ae12fa7aaa8ca5a6317868a26a367a0b69fbc1cf32a55d34eb370663016f3d2110230eba754028a56f54acf57c"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e771aa8db5a3e043e8178f39a0857ba04a3f18e4aa05743cf8d222b0b095825350ba422f63382a23d92e4149074e816a36c1cd28284d146267940b31f8818ea2"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f30313233",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "feb4fd6f9e87a56bef398b3284d2bda5b5b0e166583a66b61e538457ff0584872c21a32962b9928ffab58de4af2edd4e15d8b35570523207ff4e2a5aa7754caa"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031323334",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "462f17bf005fb1c1b9e671779f665209ec2873e3e411f98dabf240a1d5ec3f95ce6796b6fc23fe171903b502023467dec7273ff74879b92967a2a43a5a183d33"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d3338193b64553dbd38d144bea71c5915bb110e2d88180dbc5db364fd6171df317fc7268831b5aef75e4342b2fad8797ba39eddcef80e6ec08159350b1ad696d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f30313233343536",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e1590d585a3d39f7cb599abd479070966409a6846d4377acf4471d065d5db94129cc9be92573b05ed226be1e9b7cb0cabe87918589f80dadd4ef5ef25a93d28e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031323334353637",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f8f3726ac5a26cc80132493a6fedcb0e60760c09cfc84cad178175986819665e76842d7b9fedf76dddebf5d3f56faaad4477587af21606d396ae570d8e719af2"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "30186055c07949948183c850e9a756cc09937e247d9d928e869e20bafc3cd9721719d34e04a0899b92c736084550186886efba2e790d8be6ebf040b209c439a4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f30313233343536373839",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f3c4276cb863637712c241c444c5cc1e3554e0fddb174d035819dd83eb700b4ce88df3ab3841ba02085e1a99b4e17310c5341075c0458ba376c95a6818fbb3e2"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "0aa007c4dd9d5832393040a1583c930bca7dc5e77ea53add7e2b3f7c8e231368043520d4a3ef53c969b6bbfd025946f632bd7f765d53c21003b8f983f75e2a6a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "08e9464720533b23a04ec24f7ae8c103145f765387d738777d3d343477fd1c58db052142cab754ea674378e18766c53542f71970171cc4f81694246b717d7564"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d37ff7ad297993e7ec21e0f1b4b5ae719cdc83c5db687527f27516cbffa822888a6810ee5c1ca7bfe3321119be1ab7bfa0a502671c8329494df7ad6f522d440f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "dd9042f6e464dcf86b1262f6accfafbd8cfd902ed3ed89abf78ffa482dbdeeb6969842394c9a1168ae3d481a017842f660002d42447c6b22f7b72f21aae021c9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "bd965bf31e87d70327536f2a341cebc4768eca275fa05ef98f7f1b71a0351298de006fba73fe6733ed01d75801b4a928e54231b38e38c562b2e33ea1284992fa"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "65676d800617972fbd87e4b9514e1c67402b7a331096d3bfac22f1abb95374abc942f16e9ab0ead33b87c91968a6e509e119ff07787b3ef483e1dcdccf6e3022"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f40",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "939fa189699c5d2c81ddd1ffc1fa207c970b6a3685bb29ce1d3e99d42f2f7442da53e95a72907314f4588399a3ff5b0a92beb3f6be2694f9f86ecf2952d5b41c"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f4041",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c516541701863f91005f314108ceece3c643e04fc8c42fd2ff556220e616aaa6a48aeb97a84bad74782e8dff96a1a2fa949339d722edcaa32b57067041df88cc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "987fd6e0d6857c553eaebb3d34970a2c2f6e89a3548f492521722b80a1c21a153892346d2cba6444212d56da9a26e324dccbc0dcde85d4d2ee4399eec5a64e8f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f40414243",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ae56deb1c2328d9c4017706bce6e99d41349053ba9d336d677c4c27d9fd50ae6aee17e853154e1f4fe7672346da2eaa31eea53fcf24a22804f11d03da6abfc2b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f4041424344",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "49d6a608c9bde4491870498572ac31aac3fa40938b38a7818f72383eb040ad39532bc06571e13d767e6945ab77c0bdc3b0284253343f9f6c1244ebf2ff0df866"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "da582ad8c5370b4469af862aa6467a2293b2b28bd80ae0e91f425ad3d47249fdf98825cc86f14028c3308c9804c78bfeeeee461444ce243687e1a50522456a1d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f40414243444546",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d5266aa3331194aef852eed86d7b5b2633a0af1c735906f2e13279f14931a9fc3b0eac5ce9245273bd1aa92905abe16278ef7efd47694789a7283b77da3c70f8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f4041424344454647",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "2962734c28252186a9a1111c732ad4de4506d4b4480916303eb7991d659ccda07a9911914bc75c418ab7a4541757ad054796e26797feaf36e9f6ad43f14b35a4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e8b79ec5d06e111bdfafd71e9f5760f00ac8ac5d8bf768f9ff6f08b8f026096b1cc3a4c973333019f1e3553e77da3f98cb9f542e0a90e5f8a940cc58e59844b3"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f40414243444546474849",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "dfb320c44f9d41d1efdcc015f08dd5539e526e39c87d509ae6812a969e5431bf4fa7d91ffd03b981e0d544cf72d7b1c0374f8801482e6dea2ef903877eba675e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d88675118fdb55a5fb365ac2af1d217bf526ce1ee9c94b2f0090b2c58a06ca58187d7fe57c7bed9d26fca067b4110eefcd9a0a345de872abe20de368001b0745"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b893f2fc41f7b0dd6e2f6aa2e0370c0cff7df09e3acfcc0e920b6e6fad0ef747c40668417d342b80d2351e8c175f20897a062e9765e6c67b539b6ba8b9170545"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "6c67ec5697accd235c59b486d7b70baeedcbd4aa64ebd4eef3c7eac189561a726250aec4d48cadcafbbe2ce3c16ce2d691a8cce06e8879556d4483ed7165c063"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f1aa2b044f8f0c638a3f362e677b5d891d6fd2ab0765f6ee1e4987de057ead357883d9b405b9d609eea1b869d97fb16d9b51017c553f3b93c0a1e0f1296fedcd"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "cbaa259572d4aebfc1917acddc582b9f8dfaa928a198ca7acd0f2aa76a134a90252e6298a65b08186a350d5b7626699f8cb721a3ea5921b753ae3a2dce24ba3a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "fa1549c9796cd4d303dcf452c1fbd5744fd9b9b47003d920b92de34839d07ef2a29ded68f6fc9e6c45e071a2e48bd50c5084e96b657dd0404045a1ddefe282ed"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f50",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5cf2ac897ab444dcb5c8d87c495dbdb34e1838b6b629427caa51702ad0f9688525f13bec503a3c3a2c80a65e0b5715e8afab00ffa56ec455a49a1ad30aa24fcd"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f5051",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "9aaf80207bace17bb7ab145757d5696bde32406ef22b44292ef65d4519c3bb2ad41a59b62cc3e94b6fa96d32a7faadae28af7d35097219aa3fd8cda31e40c275"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "af88b163402c86745cb650c2988fb95211b94b03ef290eed9662034241fd51cf398f8073e369354c43eae1052f9b63b08191caa138aa54fea889cc7024236897"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f50515253",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "48fa7d64e1ceee27b9864db5ada4b53d00c9bc7626555813d3cd6730ab3cc06ff342d727905e33171bde6e8476e77fb1720861e94b73a2c538d254746285f430"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f5051525354",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "0e6fd97a85e904f87bfe85bbeb34f69e1f18105cf4ed4f87aec36c6e8b5f68bd2a6f3dc8a9ecb2b61db4eedb6b2ea10bf9cb0251fb0f8b344abf7f366b6de5ab"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "06622da5787176287fdc8fed440bad187d830099c94e6d04c8e9c954cda70c8bb9e1fc4a6d0baa831b9b78ef6648681a4867a11da93ee36e5e6a37d87fc63f6f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f50515253545556",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "1da6772b58fabf9c61f68d412c82f182c0236d7d575ef0b58dd22458d643cd1dfc93b03871c316d8430d312995d4197f0874c99172ba004a01ee295abac24e46"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f5051525354555657",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3cd2d9320b7b1d5fb9aab951a76023fa667be14a9124e394513918a3f44096ae4904ba0ffc150b63bc7ab1eeb9a6e257e5c8f000a70394a5afd842715de15f29"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "04cdc14f7434e0b4be70cb41db4c779a88eaef6accebcb41f2d42fffe7f32a8e281b5c103a27021d0d08362250753cdf70292195a53a48728ceb5844c2d98bab"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f50515253545556575859",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "9071b7a8a075d0095b8fb3ae5113785735ab98e2b52faf91d5b89e44aac5b5d4ebbf91223b0ff4c71905da55342e64655d6ef8c89a4768c3f93a6dc0366b5bc8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ebb30240dd96c7bc8d0abe49aa4edcbb4afdc51ff9aaf720d3f9e7fbb0f9c6d6571350501769fc4ebd0b2141247ff400d4fd4be414edf37757bb90a32ac5c65a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8532c58bf3c8015d9d1cbe00eef1f5082f8f3632fbe9f1ed4f9dfb1fa79e8283066d77c44c4af943d76b300364aecbd0648c8a8939bd204123f4b56260422dec"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "fe9846d64f7c7708696f840e2d76cb4408b6595c2f81ec6a28a7f2f20cb88cfe6ac0b9e9b8244f08bd7095c350c1d0842f64fb01bb7f532dfcd47371b0aeeb79"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "28f17ea6fb6c42092dc264257e29746321fb5bdaea9873c2a7fa9d8f53818e899e161bc77dfe8090afd82bf2266c5c1bc930a8d1547624439e662ef695f26f24"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ec6b7d7f030d4850acae3cb615c21dd25206d63e84d1db8d957370737ba0e98467ea0ce274c66199901eaec18a08525715f53bfdb0aacb613d342ebdceeddc3b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b403d3691c03b0d3418df327d5860d34bbfcc4519bfbce36bf33b208385fadb9186bc78a76c489d89fd57e7dc75412d23bcd1dae8470ce9274754bb8585b13c5"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f60",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "31fc79738b8772b3f55cd8178813b3b52d0db5a419d30ba9495c4b9da0219fac6df8e7c23a811551a62b827f256ecdb8124ac8a6792ccfecc3b3012722e94463"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f6061",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "bb2039ec287091bcc9642fc90049e73732e02e577e2862b32216ae9bedcd730c4c284ef3968c368b7d37584f97bd4b4dc6ef6127acfe2e6ae2509124e66c8af4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f53d68d13f45edfcb9bd415e2831e938350d5380d3432278fc1c0c381fcb7c65c82dafe051d8c8b0d44e0974a0e59ec7bf7ed0459f86e96f329fc79752510fd3"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f60616263",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8d568c7984f0ecdf7640fbc483b5d8c9f86634f6f43291841b309a350ab9c1137d24066b09da9944bac54d5bb6580d836047aac74ab724b887ebf93d4b32eca9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f6061626364",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c0b65ce5a96ff774c456cac3b5f2c4cd359b4ff53ef93a3da0778be4900d1e8da1601e769e8f1b02d2a2f8c5b9fa10b44f1c186985468feeb008730283a6657d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "4900bba6f5fb103ece8ec96ada13a5c3c85488e05551da6b6b33d988e611ec0fe2e3c2aa48ea6ae8986a3a231b223c5d27cec2eadde91ce07981ee652862d1e4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f60616263646566",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c7f5c37c7285f927f76443414d4357ff789647d7a005a5a787e03c346b57f49f21b64fa9cf4b7e45573e23049017567121a9c3d4b2b73ec5e9413577525db45a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f6061626364656667",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ec7096330736fdb2d64b5653e7475da746c23a4613a82687a28062d3236364284ac01720ffb406cfe265c0df626a188c9e5963ace5d3d5bb363e32c38c2190a6"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "82e744c75f4649ec52b80771a77d475a3bc091989556960e276a5f9ead92a03f718742cdcfeaee5cb85c44af198adc43a4a428f5f0c2ddb0be36059f06d7df73"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f60616263646566676869",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "2834b7a7170f1f5b68559ab78c1050ec21c919740b784a9072f6e5d69f828d70c919c5039fb148e39e2c8a52118378b064ca8d5001cd10a5478387b966715ed6"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "16b4ada883f72f853bb7ef253efcab0c3e2161687ad61543a0d2824f91c1f81347d86be709b16996e17f2dd486927b0288ad38d13063c4a9672c39397d3789b6"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "78d048f3a69d8b54ae0ed63a573ae350d89f7c6cf1f3688930de899afa037697629b314e5cd303aa62feea72a25bf42b304b6c6bcb27fae21c16d925e1fbdac3"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "0f746a48749287ada77a82961f05a4da4abdb7d77b1220f836d09ec814359c0ec0239b8c7b9ff9e02f569d1b301ef67c4612d1de4f730f81c12c40cc063c5caa"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f0fc859d3bd195fbdc2d591e4cdac15179ec0f1dc821c11df1f0c1d26e6260aaa65b79fafacafd7d3ad61e600f250905f5878c87452897647a35b995bcadc3a3"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "2620f687e8625f6a412460b42e2cef67634208ce10a0cbd4dff7044a41b7880077e9f8dc3b8d1216d3376a21e015b58fb279b521d83f9388c7382c8505590b9b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "227e3aed8d2cb10b918fcb04f9de3e6d0a57e08476d93759cd7b2ed54a1cbf0239c528fb04bbf288253e601d3bc38b21794afef90b17094a182cac557745e75f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f70",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "1a929901b09c25f27d6b35be7b2f1c4745131fdebca7f3e2451926720434e0db6e74fd693ad29b777dc3355c592a361c4873b01133a57c2e3b7075cbdb86f4fc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f7071",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5fd7968bc2fe34f220b5e3dc5af9571742d73b7d60819f2888b629072b96a9d8ab2d91b82d0a9aaba61bbd39958132fcc4257023d1eca591b3054e2dc81c8200"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "dfcce8cf32870cc6a503eadafc87fd6f78918b9b4d0737db6810be996b5497e7e5cc80e312f61e71ff3e9624436073156403f735f56b0b01845c18f6caf772e6"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f70717273",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "02f7ef3a9ce0fff960f67032b296efca3061f4934d690749f2d01c35c81c14f39a67fa350bc8a0359bf1724bffc3bca6d7c7bba4791fd522a3ad353c02ec5aa8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f7071727374",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "64be5c6aba65d594844ae78bb022e5bebe127fd6b6ffa5a13703855ab63b624dcd1a363f99203f632ec386f3ea767fc992e8ed9686586aa27555a8599d5b808f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f78585505c4eaa54a8b5be70a61e735e0ff97af944ddb3001e35d86c4e2199d976104b6ae31750a36a726ed285064f5981b503889fef822fcdc2898dddb7889a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f70717273747576",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e4b5566033869572edfd87479a5bb73c80e8759b91232879d96b1dda36c012076ee5a2ed7ae2de63ef8406a06aea82c188031b560beafb583fb3de9e57952a7e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f7071727374757677",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e1b3e7ed867f6c9484a2a97f7715f25e25294e992e41f6a7c161ffc2adc6daaeb7113102d5e6090287fe6ad94ce5d6b739c6ca240b05c76fb73f25dd024bf935"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "85fd085fdc12a080983df07bd7012b0d402a0f4043fcb2775adf0bad174f9b08d1676e476985785c0a5dcc41dbff6d95ef4d66a3fbdc4a74b82ba52da0512b74"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f70717273747576777879",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "aed8fa764b0fbff821e05233d2f7b0900ec44d826f95e93c343c1bc3ba5a24374b1d616e7e7aba453a0ada5e4fab5382409e0d42ce9c2bc7fb39a99c340c20f0"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7ba3b2e297233522eeb343bd3ebcfd835a04007735e87f0ca300cbee6d416565162171581e4020ff4cf176450f1291ea2285cb9ebffe4c56660627685145051c"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "de748bcf89ec88084721e16b85f30adb1a6134d664b5843569babc5bbd1a15ca9b61803c901a4fef32965a1749c9f3a4e243e173939dc5a8dc495c671ab52145"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "aaf4d2bdf200a919706d9842dce16c98140d34bc433df320aba9bd429e549aa7a3397652a4d768277786cf993cde2338673ed2e6b66c961fefb82cd20c93338f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c408218968b788bf864f0997e6bc4c3dba68b276e2125a4843296052ff93bf5767b8cdce7131f0876430c1165fec6c4f47adaa4fd8bcfacef463b5d3d0fa61a0"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "76d2d819c92bce55fa8e092ab1bf9b9eab237a25267986cacf2b8ee14d214d730dc9a5aa2d7b596e86a1fd8fa0804c77402d2fcd45083688b218b1cdfa0dcbcb"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "72065ee4dd91c2d8509fa1fc28a37c7fc9fa7d5b3f8ad3d0d7a25626b57b1b44788d4caf806290425f9890a3a2a35a905ab4b37acfd0da6e4517b2525c9651e4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f80",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "64475dfe7600d7171bea0b394e27c9b00d8e74dd1e416a79473682ad3dfdbb706631558055cfc8a40e07bd015a4540dcdea15883cbbf31412df1de1cd4152b91"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f8081",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "12cd1674a4488a5d7c2b3160d2e2c4b58371bedad793418d6f19c6ee385d70b3e06739369d4df910edb0b0a54cbff43d54544cd37ab3a06cfa0a3ddac8b66c89"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "60756966479dedc6dd4bcff8ea7d1d4ce4d4af2e7b097e32e3763518441147cc12b3c0ee6d2ecabf1198cec92e86a3616fba4f4e872f5825330adbb4c1dee444"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f80818283",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "a7803bcb71bc1d0f4383dde1e0612e04f872b715ad30815c2249cf34abb8b024915cb2fc9f4e7cc4c8cfd45be2d5a91eab0941c7d270e2da4ca4a9f7ac68663a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f8081828384",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b84ef6a7229a34a750d9a98ee2529871816b87fbe3bc45b45fa5ae82d5141540211165c3c5d7a7476ba5a4aa06d66476f0d9dc49a3f1ee72c3acabd498967414"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "fae4b6d8efc3f8c8e64d001dabec3a21f544e82714745251b2b4b393f2f43e0da3d403c64db95a2cb6e23ebb7b9e94cdd5ddac54f07c4a61bd3cb10aa6f93b49"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f80818283848586",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "34f7286605a122369540141ded79b8957255da2d4155abbf5a8dbb89c8eb7ede8eeef1daa46dc29d751d045dc3b1d658bb64b80ff8589eddb3824b13da235a6b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f8081828384858687",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3b3b48434be27b9eababba43bf6b35f14b30f6a88dc2e750c358470d6b3aa3c18e47db4017fa55106d8252f016371a00f5f8b070b74ba5f23cffc5511c9f09f0"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ba289ebd6562c48c3e10a8ad6ce02e73433d1e93d7c9279d4d60a7e879ee11f441a000f48ed9f7c4ed87a45136d7dccdca482109c78a51062b3ba4044ada2469"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f80818283848586878889",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "022939e2386c5a37049856c850a2bb10a13dfea4212b4c732a8840a9ffa5faf54875c5448816b2785a007da8a8d2bc7d71a54e4e6571f10b600cbdb25d13ede3"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e6fec19d89ce8717b1a087024670fe026f6c7cbda11caef959bb2d351bf856f8055d1c0ebdaaa9d1b17886fc2c562b5e99642fc064710c0d3488a02b5ed7f6fd"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "94c96f02a8f576aca32ba61c2b206f907285d9299b83ac175c209a8d43d53bfe683dd1d83e7549cb906c28f59ab7c46f8751366a28c39dd5fe2693c9019666c8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "31a0cd215ebd2cb61de5b9edc91e6195e31c59a5648d5c9f737e125b2605708f2e325ab3381c8dce1a3e958886f1ecdc60318f882cfe20a24191352e617b0f21"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "91ab504a522dce78779f4c6c6ba2e6b6db5565c76d3e7e7c920caf7f757ef9db7c8fcf10e57f03379ea9bf75eb59895d96e149800b6aae01db778bb90afbc989"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d85cabc6bd5b1a01a5afd8c6734740da9fd1c1acc6db29bfc8a2e5b668b028b6b3154bfb8703fa3180251d589ad38040ceb707c4bad1b5343cb426b61eaa49c1"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d62efbec2ca9c1f8bd66ce8b3f6a898cb3f7566ba6568c618ad1feb2b65b76c3ce1dd20f7395372faf28427f61c9278049cf0140df434f5633048c86b81e0399"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f90",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7c8fdc6175439e2c3db15bafa7fb06143a6a23bc90f449e79deef73c3d492a671715c193b6fea9f036050b946069856b897e08c00768f5ee5ddcf70b7cd6d0e0"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f9091",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "58602ee7468e6bc9df21bd51b23c005f72d6cb013f0a1b48cbec5eca299299f97f09f54a9a01483eaeb315a6478bad37ba47ca1347c7c8fc9e6695592c91d723"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "27f5b79ed256b050993d793496edf4807c1d85a7b0a67c9c4fa99860750b0ae66989670a8ffd7856d7ce411599e58c4d77b232a62bef64d15275be46a68235ff"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f90919293",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3957a976b9f1887bf004a8dca942c92d2b37ea52600f25e0c9bc5707d0279c00c6e85a839b0d2d8eb59c51d94788ebe62474a791cadf52cccf20f5070b6573fc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f9091929394",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "eaa2376d55380bf772ecca9cb0aa4668c95c707162fa86d518c8ce0ca9bf7362b9f2a0adc3ff59922df921b94567e81e452f6c1a07fc817cebe99604b3505d38"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c1e2c78b6b2734e2480ec550434cb5d613111adcc21d475545c3b1b7e6ff12444476e5c055132e2229dc0f807044bb919b1a5662dd38a9ee65e243a3911aed1a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f90919293949596",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8ab48713389dd0fcf9f965d3ce66b1e559a1f8c58741d67683cd971354f452e62d0207a65e436c5d5d8f8ee71c6abfe50e669004c302b31a7ea8311d4a916051"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f9091929394959697",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "24ce0addaa4c65038bd1b1c0f1452a0b128777aabc94a29df2fd6c7e2f85f8ab9ac7eff516b0e0a825c84a24cfe492eaad0a6308e46dd42fe8333ab971bb30ca"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5154f929ee03045b6b0c0004fa778edee1d139893267cc84825ad7b36c63de32798e4a166d24686561354f63b00709a1364b3c241de3febf0754045897467cd4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f90919293949596979899",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e74e907920fd87bd5ad636dd11085e50ee70459c443e1ce5809af2bc2eba39f9e6d7128e0e3712c316da06f4705d78a4838e28121d4344a2c79c5e0db307a677"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "bf91a22334bac20f3fd80663b3cd06c4e8802f30e6b59f90d3035cc9798a217ed5a31abbda7fa6842827bdf2a7a1c21f6fcfccbb54c6c52926f32da816269be1"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d9d5c74be5121b0bd742f26bffb8c89f89171f3f934913492b0903c271bbe2b3395ef259669bef43b57f7fcc3027db01823f6baee66e4f9fead4d6726c741fce"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "50c8b8cf34cd879f80e2faab3230b0c0e1cc3e9dcadeb1b9d97ab923415dd9a1fe38addd5c11756c67990b256e95ad6d8f9fedce10bf1c90679cde0ecf1be347"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "0a386e7cd5dd9b77a035e09fe6fee2c8ce61b5383c87ea43205059c5e4cd4f4408319bb0a82360f6a58e6c9ce3f487c446063bf813bc6ba535e17fc1826cfc91"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "1f1459cb6b61cbac5f0efe8fc487538f42548987fcd56221cfa7beb22504769e792c45adfb1d6b3d60d7b749c8a75b0bdf14e8ea721b95dca538ca6e25711209"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9f",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e58b3836b7d8fedbb50ca5725c6571e74c0785e97821dab8b6298c10e4c079d4a6cdf22f0fedb55032925c16748115f01a105e77e00cee3d07924dc0d8f90659"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b929cc6505f020158672deda56d0db081a2ee34c00c1100029bdf8ea98034fa4bf3e8655ec697fe36f40553c5bb46801644a627d3342f4fc92b61f03290fb381"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "72d353994b49d3e03153929a1e4d4f188ee58ab9e72ee8e512f29bc773913819ce057ddd7002c0433ee0a16114e3d156dd2c4a7e80ee53378b8670f23e33ef56"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c70ef9bfd775d408176737a0736d68517ce1aaad7e81a93c8c1ed967ea214f56c8a377b1763e676615b60f3988241eae6eab9685a5124929d28188f29eab06f7"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c230f0802679cb33822ef8b3b21bf7a9a28942092901d7dac3760300831026cf354c9232df3e084d9903130c601f63c1f4a4a4b8106e468cd443bbe5a734f45f"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "6f43094cafb5ebf1f7a4937ec50f56a4c9da303cbb55ac1f27f1f1976cd96beda9464f0e7b9c54620b8a9fba983164b8be3578425a024f5fe199c36356b88972"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3745273f4c38225db2337381871a0c6aafd3af9b018c88aa02025850a5dc3a42a1a3e03e56cbf1b0876d63a441f1d2856a39b8801eb5af325201c415d65e97fe"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c50c44cca3ec3edaae779a7e179450ebdda2f97067c690aa6c5a4ac7c30139bb27c0df4db3220e63cb110d64f37ffe078db72653e2daacf93ae3f0a2d1a7eb2e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8aef263e385cbc61e19b28914243262af5afe8726af3ce39a79c27028cf3ecd3f8d2dfd9cfc9ad91b58f6f20778fd5f02894a3d91c7d57d1e4b866a7f364b6be"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "28696141de6e2d9bcb3235578a66166c1448d3e905a1b482d423be4bc5369bc8c74dae0acc9cc123e1d8ddce9f97917e8c019c552da32d39d2219b9abf0fa8c8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "2fb9eb2085830181903a9dafe3db428ee15be7662224efd643371fb25646aee716e531eca69b2bdc8233f1a8081fa43da1500302975a77f42fa592136710e9dc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aa",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "66f9a7143f7a3314a669bf2e24bbb35014261d639f495b6c9c1f104fe8e320aca60d4550d69d52edbd5a3cdeb4014ae65b1d87aa770b69ae5c15f4330b0b0ad8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaab",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f4c4dd1d594c3565e3e25ca43dad82f62abea4835ed4cd811bcd975e46279828d44d4c62c3679f1b7f7b9dd4571d7b49557347b8c5460cbdc1bef690fb2a08c0"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabac",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8f1dc9649c3a84551f8f6e91cac68242a43b1f8f328ee92280257387fa7559aa6db12e4aeadc2d26099178749c6864b357f3f83b2fb3efa8d2a8db056bed6bcc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacad",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3139c1a7f97afd1675d460ebbc07f2728aa150df849624511ee04b743ba0a833092f18c12dc91b4dd243f333402f59fe28abdbbbae301e7b659c7a26d5c0f979"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadae",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "06f94a2996158a819fe34c40de3cf0379fd9fb85b3e363ba3926a0e7d960e3f4c2e0c70c7ce0ccb2a64fc29869f6e7ab12bd4d3f14fce943279027e785fb5c29"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeaf",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c29c399ef3eee8961e87565c1ce263925fc3d0ce267d13e48dd9e732ee67b0f69fad56401b0f10fcaac119201046cca28c5b14abdea3212ae65562f7f138db3d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "4cec4c9df52eef05c3f6faaa9791bc7445937183224ecc37a1e58d0132d35617531d7e795f52af7b1eb9d147de1292d345fe341823f8e6bc1e5badca5c656108"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "898bfbae93b3e18d00697eab7d9704fa36ec339d076131cefdf30edbe8d9cc81c3a80b129659b163a323bab9793d4feed92d54dae966c77529764a09be88db45"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ee9bd0469d3aaf4f14035be48a2c3b84d9b4b1fff1d945e1f1c1d38980a951be197b25fe22c731f20aeacc930ba9c4a1f4762227617ad350fdabb4e80273a0f4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3d4d3113300581cd96acbf091c3d0f3c310138cd6979e6026cde623e2dd1b24d4a8638bed1073344783ad0649cc6305ccec04beb49f31c633088a99b65130267"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "95c0591ad91f921ac7be6d9ce37e0663ed8011c1cfd6d0162a5572e94368bac02024485e6a39854aa46fe38e97d6c6b1947cd272d86b06bb5b2f78b9b68d559d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "227b79ded368153bf46c0a3ca978bfdbef31f3024a5665842468490b0ff748ae04e7832ed4c9f49de9b1706709d623e5c8c15e3caecae8d5e433430ff72f20eb"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5d34f3952f0105eef88ae8b64c6ce95ebfade0e02c69b08762a8712d2e4911ad3f941fc4034dc9b2e479fdbcd279b902faf5d838bb2e0c6495d372b5b7029813"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7f939bf8353abce49e77f14f3750af20b7b03902e1a1e7fb6aaf76d0259cd401a83190f15640e74f3e6c5a90e839c7821f6474757f75c7bf9002084ddc7a62dc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "062b61a2f9a33a71d7d0a06119644c70b0716a504de7e5e1be49bd7b86e7ed6817714f9f0fc313d06129597e9a2235ec8521de36f7290a90ccfc1ffa6d0aee29"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f29e01eeae64311eb7f1c6422f946bf7bea36379523e7b2bbaba7d1d34a22d5ea5f1c5a09d5ce1fe682cced9a4798d1a05b46cd72dff5c1b355440b2a2d476bc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9ba",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ec38cd3bbab3ef35d7cb6d5c914298351d8a9dc97fcee051a8a02f58e3ed6184d0b7810a5615411ab1b95209c3c810114fdeb22452084e77f3f847c6dbaafe16"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babb",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c2aef5e0ca43e82641565b8cb943aa8ba53550caef793b6532fafad94b816082f0113a3ea2f63608ab40437ecc0f0229cb8fa224dcf1c478a67d9b64162b92d1"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbc",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "15f534efff7105cd1c254d074e27d5898b89313b7d366dc2d7d87113fa7d53aae13f6dba487ad8103d5e854c91fdb6e1e74b2ef6d1431769c30767dde067a35c"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbd",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "89acbca0b169897a0a2714c2df8c95b5b79cb69390142b7d6018bb3e3076b099b79a964152a9d912b1b86412b7e372e9cecad7f25d4cbab8a317be36492a67d7"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbe",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e3c0739190ed849c9c962fd9dbb55e207e624fcac1eb417691515499eea8d8267b7e8f1287a63633af5011fde8c4ddf55bfdf722edf88831414f2cfaed59cb9a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebf",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8d6cf87c08380d2d1506eee46fd4222d21d8c04e585fbfd08269c98f702833a156326a0724656400ee09351d57b440175e2a5de93cc5f80db6daf83576cf75fa"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "da24bede383666d563eeed37f6319baf20d5c75d1635a6ba5ef4cfa1ac95487e96f8c08af600aab87c986ebad49fc70a58b4890b9c876e091016daf49e1d322e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f9d1d1b1e87ea7ae753a029750cc1cf3d0157d41805e245c5617bb934e732f0ae3180b78e05bfe76c7c3051e3e3ac78b9b50c05142657e1e03215d6ec7bfd0fc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "11b7bc1668032048aa43343de476395e814bbbc223678db951a1b03a021efac948cfbe215f97fe9a72a2f6bc039e3956bfa417c1a9f10d6d7ba5d3d32ff323e5"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b8d9000e4fc2b066edb91afee8e7eb0f24e3a201db8b6793c0608581e628ed0bcc4e5aa6787992a4bcc44e288093e63ee83abd0bc3ec6d0934a674a4da13838a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ce325e294f9b6719d6b61278276ae06a2564c03bb0b783fafe785bdf89c7d5acd83e78756d301b445699024eaeb77b54d477336ec2a4f332f2b3f88765ddb0c3"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "29acc30e9603ae2fccf90bf97e6cc463ebe28c1b2f9b4b765e70537c25c702a29dcbfbf14c99c54345ba2b51f17b77b5f15db92bbad8fa95c471f5d070a137cc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3379cbaae562a87b4c0425550ffdd6bfe1203f0d666cc7ea095be407a5dfe61ee91441cd5154b3e53b4f5fb31ad4c7a9ad5c7af4ae679aa51a54003a54ca6b2d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3095a349d245708c7cf550118703d7302c27b60af5d4e67fc978f8a4e60953c7a04f92fcf41aee64321ccb707a895851552b1e37b00bc5e6b72fa5bcef9e3fff"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "07262d738b09321f4dbccec4bb26f48cb0f0ed246ce0b31b9a6e7bc683049f1f3e5545f28ce932dd985c5ab0f43bd6de0770560af329065ed2e49d34624c2cbb"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b6405eca8ee3316c87061cc6ec18dba53e6c250c63ba1f3bae9e55dd3498036af08cd272aa24d713c6020d77ab2f3919af1a32f307420618ab97e73953994fb4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9ca",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "7ee682f63148ee45f6e5315da81e5c6e557c2c34641fc509c7a5701088c38a74756168e2cd8d351e88fd1a451f360a01f5b2580f9b5a2e8cfc138f3dd59a3ffc"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacb",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "1d263c179d6b268f6fa016f3a4f29e943891125ed8593c81256059f5a7b44af2dcb2030d175c00e62ecaf7ee96682aa07ab20a611024a28532b1c25b86657902"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcc",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "106d132cbdb4cd2597812846e2bc1bf732fec5f0a5f65dbb39ec4e6dc64ab2ce6d24630d0f15a805c3540025d84afa98e36703c3dbee713e72dde8465bc1be7e"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccd",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "0e79968226650667a8d862ea8da4891af56a4e3a8b6d1750e394f0dea76d640d85077bcec2cc86886e506751b4f6a5838f7f0b5fef765d9dc90dcdcbaf079f08"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdce",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "521156a82ab0c4e566e5844d5e31ad9aaf144bbd5a464fdca34dbd5717e8ff711d3ffebbfa085d67fe996a34f6d3e4e60b1396bf4b1610c263bdbb834d560816"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecf",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "1aba88befc55bc25efbce02db8b9933e46f57661baeabeb21cc2574d2a518a3cba5dc5a38e49713440b25f9c744e75f6b85c9d8f4681f676160f6105357b8406"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5a9949fcb2c473cda968ac1b5d08566dc2d816d960f57e63b898fa701cf8ebd3f59b124d95bfbbedc5f1cf0e17d5eaed0c02c50b69d8a402cabcca4433b51fd4"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b0cead09807c672af2eb2b0f06dde46cf5370e15a4096b1a7d7cbb36ec31c205fbefca00b7a4162fa89fb4fb3eb78d79770c23f44e7206664ce3cd931c291e5d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "bb6664931ec97044e45b2ae420ae1c551a8874bc937d08e969399c3964ebdba8346cdd5d09caafe4c28ba7ec788191ceca65ddd6f95f18583e040d0f30d0364d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "65bc770a5faa3792369803683e844b0be7ee96f29f6d6a35568006bd5590f9a4ef639b7a8061c7b0424b66b60ac34af3119905f33a9d8c3ae18382ca9b689900"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "ea9b4dca333336aaf839a45c6eaa48b8cb4c7ddabffea4f643d6357ea6628a480a5b45f2b052c1b07d1fedca918b6f1139d80f74c24510dcbaa4be70eacc1b06"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "e6342fb4a780ad975d0e24bce149989b91d360557e87994f6b457b895575cc02d0c15bad3ce7577f4c63927ff13f3e381ff7e72bdbe745324844a9d27e3f1c01"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3e209c9b33e8e461178ab46b1c64b49a07fb745f1c8bc95fbfb94c6b87c69516651b264ef980937fad41238b91ddc011a5dd777c7efd4494b4b6ecd3a9c22ac0"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "fd6a3d5b1875d80486d6e69694a56dbb04a99a4d051f15db2689776ba1c4882e6d462a603b7015dc9f4b7450f05394303b8652cfb404a266962c41bae6e18a94"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "951e27517e6bad9e4195fc8671dee3e7e9be69cee1422cb9fecfce0dba875f7b310b93ee3a3d558f941f635f668ff832d2c1d033c5e2f0997e4c66f147344e02"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8eba2f874f1ae84041903c7c4253c82292530fc8509550bfdc34c95c7e2889d5650b0ad8cb988e5c4894cb87fbfbb19612ea93ccc4c5cad17158b9763464b492"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9da",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "16f712eaa1b7c6354719a8e7dbdfaf55e4063a4d277d947550019b38dfb564830911057d50506136e2394c3b28945cc964967d54e3000c2181626cfb9b73efd2"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadb",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c39639e7d5c7fb8cdd0fd3e6a52096039437122f21c78f1679cea9d78a734c56ecbeb28654b4f18e342c331f6f7229ec4b4bc281b2d80a6eb50043f31796c88c"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdc",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "72d081af99f8a173dcc9a0ac4eb3557405639a29084b54a40172912a2f8a395129d5536f0918e902f9e8fa6000995f4168ddc5f893011be6a0dbc9b8a1a3f5bb"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdd",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c11aa81e5efd24d5fc27ee586cfd8847fbb0e27601ccece5ecca0198e3c7765393bb74457c7e7a27eb9170350e1fb53857177506be3e762cc0f14d8c3afe9077"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcddde",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c28f2150b452e6c0c424bcde6f8d72007f9310fed7f2f87de0dbb64f4479d6c1441ba66f44b2accee61609177ed340128b407ecec7c64bbe50d63d22d8627727"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedf",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f63d88122877ec30b8c8b00d22e89000a966426112bd44166e2f525b769ccbe9b286d437a0129130dde1a86c43e04bedb594e671d98283afe64ce331de9828fd"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "348b0532880b88a6614a8d7408c3f913357fbb60e995c60205be9139e74998aede7f4581e42f6b52698f7fa1219708c14498067fd1e09502de83a77dd281150c"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "5133dc8bef725359dff59792d85eaf75b7e1dcd1978b01c35b1b85fcebc63388ad99a17b6346a217dc1a9622ebd122ecf6913c4d31a6b52a695b86af00d741a0"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "2753c4c0e98ecad806e88780ec27fccd0f5c1ab547f9e4bf1659d192c23aa2cc971b58b6802580baef8adc3b776ef7086b2545c2987f348ee3719cdef258c403"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b1663573ce4b9d8caefc865012f3e39714b9898a5da6ce17c25a6a47931a9ddb9bbe98adaa553beed436e89578455416c2a52a525cf2862b8d1d49a2531b7391"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "64f58bd6bfc856f5e873b2a2956ea0eda0d6db0da39c8c7fc67c9f9feefcff3072cdf9e6ea37f69a44f0c61aa0da3693c2db5b54960c0281a088151db42b11e8"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "0764c7be28125d9065c4b98a69d60aede703547c66a12e17e1c618994132f5ef82482c1e3fe3146cc65376cc109f0138ed9a80e49f1f3c7d610d2f2432f20605"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "f748784398a2ff03ebeb07e155e66116a839741a336e32da71ec696001f0ad1b25cd48c69cfca7265eca1dd71904a0ce748ac4124f3571076dfa7116a9cf00e9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3f0dbc0186bceb6b785ba78d2a2a013c910be157bdaffae81bb6663b1a73722f7f1228795f3ecada87cf6ef0078474af73f31eca0cc200ed975b6893f761cb6d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d4762cd4599876ca75b2b8fe249944dbd27ace741fdab93616cbc6e425460feb51d4e7adcc38180e7fc47c89024a7f56191adb878dfde4ead62223f5a2610efe"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "cd36b3d5b4c91b90fcbba79513cfee1907d8645a162afd0cd4cf4192d4a5f4c892183a8eacdb2b6b6a9d9aa8c11ac1b261b380dbee24ca468f1bfd043c58eefe"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9ea",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "98593452281661a53c48a9d8cd790826c1a1ce567738053d0bee4a91a3d5bd92eefdbabebe3204f2031ca5f781bda99ef5d8ae56e5b04a9e1ecd21b0eb05d3e1"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaeb",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "771f57dd2775ccdab55921d3e8e30ccf484d61fe1c1b9c2ae819d0fb2a12fab9be70c4a7a138da84e8280435daade5bbe66af0836a154f817fb17f3397e725a3"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebec",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "c60897c6f828e21f16fbb5f15b323f87b6c8955eabf1d38061f707f608abdd993fac3070633e286cf8339ce295dd352df4b4b40b2f29da1dd50b3a05d079e6bb"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebeced",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "8210cd2c2d3b135c2cf07fa0d1433cd771f325d075c6469d9c7f1ba0943cd4ab09808cabf4acb9ce5bb88b498929b4b847f681ad2c490d042db2aec94214b06b"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedee",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "1d4edfffd8fd80f7e4107840fa3aa31e32598491e4af7013c197a65b7f36dd3ac4b478456111cd4309d9243510782fa31b7c4c95fa951520d020eb7e5c36e4ef"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeef",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "af8e6e91fab46ce4873e1a50a8ef448cc29121f7f74deef34a71ef89cc00d9274bc6c2454bbb3230d8b2ec94c62b1dec85f3593bfa30ea6f7a44d7c09465a253"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "29fd384ed4906f2d13aa9fe7af905990938bed807f1832454a372ab412eea1f5625a1fcc9ac8343b7c67c5aba6e0b1cc4644654913692c6b39eb9187ceacd3ec"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "a268c7885d9874a51c44dffed8ea53e94f78456e0b2ed99ff5a3924760813826d960a15edbedbb5de5226ba4b074e71b05c55b9756bb79e55c02754c2c7b6c8a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "0cf8545488d56a86817cd7ecb10f7116b7ea530a45b6ea497b6c72c997e09e3d0da8698f46bb006fc977c2cd3d1177463ac9057fdd1662c85d0c126443c10473"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b39614268fdd8781515e2cfebf89b4d5402bab10c226e6344e6b9ae000fb0d6c79cb2f3ec80e80eaeb1980d2f8698916bd2e9f747236655116649cd3ca23a837"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "74bef092fc6f1e5dba3663a3fb003b2a5ba257496536d99f62b9d73f8f9eb3ce9ff3eec709eb883655ec9eb896b9128f2afc89cf7d1ab58a72f4a3bf034d2b4a"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "3a988d38d75611f3ef38b8774980b33e573b6c57bee0469ba5eed9b44f29945e7347967fba2c162e1c3be7f310f2f75ee2381e7bfd6b3f0baea8d95dfb1dafb1"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "58aedfce6f67ddc85a28c992f1c0bd0969f041e66f1ee88020a125cbfcfebcd61709c9c4eba192c15e69f020d462486019fa8dea0cd7a42921a19d2fe546d43d"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "9347bd291473e6b4e368437b8e561e065f649a6d8ada479ad09b1999a8f26b91cf6120fd3bfe014e83f23acfa4c0ad7b3712b2c3c0733270663112ccd9285cd9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "b32163e7c5dbb5f51fdc11d2eac875efbbcb7e7699090a7e7ff8a8d50795af5d74d9ff98543ef8cdf89ac13d0485278756e0ef00c817745661e1d59fe38e7537"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "1085d78307b1c4b008c57a2e7e5b234658a0a82e4ff1e4aaac72b312fda0fe27d233bc5b10e9cc17fdc7697b540c7d95eb215a19a1a0e20e1abfa126efd568c7"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9fa",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "4e5c734c7dde011d83eac2b7347b373594f92d7091b9ca34cb9c6f39bdf5a8d2f134379e16d822f6522170ccf2ddd55c84b9e6c64fc927ac4cf8dfb2a17701f2"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9fafb",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "695d83bd990a1117b3d0ce06cc888027d12a054c2677fd82f0d4fbfc93575523e7991a5e35a3752e9b70ce62992e268a877744cdd435f5f130869c9a2074b338"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9fafbfc",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "a6213743568e3b3158b9184301f3690847554c68457cb40fc9a4b8cfd8d4a118c301a07737aeda0f929c68913c5f51c80394f53bff1c3e83b2e40ca97eba9e15"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9fafbfcfd",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "d444bfa2362a96df213d070e33fa841f51334e4e76866b8139e8af3bb3398be2dfaddcbc56b9146de9f68118dc5829e74b0c28d7711907b121f9161cb92b69a9"
- ),
-
- KnownAnswerTest(
- input = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9fafbfcfdfe",
- key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f",
- hash = "142709d62e28fcccd0af97fad0f8465b971e82201dc51070faa0372aa43e92484be1c1e73ba10906d5d1853db6a4106e0a7bf9800d373d6dee2d46d62ef2a461"
- )
- )
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Test.kt
deleted file mode 100644
index f77caf2..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256Test.kt
+++ /dev/null
@@ -1,82 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-class Sha256Test {
-
-
- @Test
- fun testWellKnownValue() {
-
- val result = Sha256Pure.digest("abc".encodeToUByteArray())
- val expectedResult = "ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
-
-
- }
-
-
- @Test
- fun testWellKnownDoubleBlock() {
-
- val resultDoubleBlock = Sha256Pure.digest("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq".encodeToUByteArray())
- val expectedResultForDoubleBlock = "248d6a61d20638b8e5c026930c3e6039a33ce45964ff2167f6ecedd419db06c1"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun testWellKnown3() { //It's good that I'm consistent with names.
-
-
- val resultDoubleBlock = Sha256Pure.digest("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu".encodeToUByteArray())
- println(resultDoubleBlock.map{ it.toString(16)}.joinToString(separator = ""))
- val expectedResultForDoubleBlock = "cf5b16a778af8380036ce59e7b0492370b249b11e8f07a51afac45037afee9d1"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun testWellKnownLong() {
- val inputBuilder = StringBuilder()
- for (i in 0 until 1000000) {
- inputBuilder.append("a")
- }
- val resultDoubleBlock = Sha256Pure.digest(inputMessage = (inputBuilder.toString()).encodeToByteArray().map { it.toUByte() }.toUByteArray())
- val expectedResultForDoubleBlock = "cdc76e5c9914fb9281a1c7e284d73e67f1809a48a497200e046d39ccc7112cd0"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256UpdateableTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256UpdateableTest.kt
deleted file mode 100644
index 8e18be7..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha256UpdateableTest.kt
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.Ignore
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-
-class Sha256UpdatableTest {
-
-
- @Test
- fun testWellKnownValue() {
- val sha256 = Sha256Pure()
- sha256.update("abc")
- val result = sha256.digest()
- val expectedResult = "ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun testWellKnownDoubleBlock() {
- val sha256 = Sha256Pure()
- sha256.update(data = "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq")
- val resultDoubleBlock = sha256.digest()
- println(resultDoubleBlock.map{ it.toString(16)}.joinToString(separator = ""))
- val expectedResultForDoubleBlock = "248d6a61d20638b8e5c026930c3e6039a33ce45964ff2167f6ecedd419db06c1"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun testWellKnown3() { //It's good that I'm consistent with names.
- val sha256 = Sha256Pure()
- sha256.update(data = "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu")
- val resultDoubleBlock = sha256.digest()
- println(resultDoubleBlock.map{ it.toString(16)}.joinToString(separator = ""))
- val expectedResultForDoubleBlock = "cf5b16a778af8380036ce59e7b0492370b249b11e8f07a51afac45037afee9d1"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun testWellKnownLong() {
- val sha256 = Sha256Pure()
- for (i in 0 until 10000) {
- sha256.update("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa")
- }
- val result = sha256.digest()
- val expectedResult = "cdc76e5c9914fb9281a1c7e284d73e67f1809a48a497200e046d39ccc7112cd0"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
- }
-
- @Ignore // Takes too long on native and js, but it now finishes correctly (and surprisingly quickly) on JVM
- @Test
- fun testWellKnownLonger() {
-
- //Obtained from libsodium runs
- val roundsExpectedMap = mapOf(
- 0 to "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
- 1 to "2ff100b36c386c65a1afc462ad53e25479bec9498ed00aa5a04de584bc25301b",
- 2 to "a9161e25f5e45eddf9a4cfa8b23456ba66be8098e474dc145bfceb2a99808b89",
- 3 to "7bd37dc113762cb012b69105b6302638d414ebfcabde205669aab2b8bbe1f3c4",
- 4 to "8fa352dc79b2482d1b55777b4932aff67f52e87bafdf9b9d45d57405a672de7a",
- 5 to "a229ab9b1bce3f3281b9d06a592aadb7e765029472a6b9ebf5ecd6c45a31f2f6",
- 6 to "09b49600c40293a902e52f89478d4886cf5771faabe38f53a63f3e9051b23e32",
- 7 to "02372493fd93330a8371f1dea20f5c29e5411baa1b08ba6cb33c6ca745c364a1",
- 8 to "e38b73d311ac89575d4e69a965763cdc618d0879142574231268f2b014fd0fec",
- 9 to "37ed309f368eef8560c8cbfb1d8b619f3cc5460689984b8c687f46373ff62087",
- 0 to "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
- 1000000 to "7d9d6bcd4ffc9eb37899bbd7b5810e1762c55e4104f1b26b061349dbc67b5500",
- 2000000 to "6b324148d357b3bb6549d339cec1a2a9ce45543eca0efcece78eecb3337097c2",
- 3000000 to "3a52d0fb3383bca84dab55b2f41f0827d08325dbc65e3db4f15264597a8ac828",
- 4000000 to "afd4587cf84fe7b6ffd7146a702d9b5dd4f0b754971eef36b7e0a6c4c3e84d58",
- 5000000 to "d2b74e1a88652cce4450c3040decf40f9496ec92ad5e3443045922952db7894d",
- 6000000 to "6e27932f14dfbbce11c9c9523e8b5a11616fd7864504d607639a98f81d5c0701",
- 7000000 to "06e320b651981e13fb192805ff12a848815671d15885b636f99148b0089efabe",
- 8000000 to "acc52c42ee92c046430f6e5454670e4f82da684a157eddd393a74c6883c881a5",
- 9000000 to "493a7d3a40f3575bd5e5b4a5fec005f37392f3ce44565da314d173a062f499be",
- 10000000 to "b3c6a178986ae0f5c81875ed68da2c72c8be961e9abc05e02982f723bd52a489",
- 11000000 to "48387a098f9e919ea15ae5d1a347857f1043116e24bf9224b718120e0bfdaa9f",
- 12000000 to "3ec9b9e64073f1c89f6d1c817a75610294d32c33d089af45540a352634e4a74a",
- 13000000 to "cfb7c272408acdabf35c5cf1e2c0e2e81092d4e86bf8d51575a8a3baea2e7f8c",
- 14000000 to "aa678e14a7d9a160177d52f153f30edd20c7f8a25fe36a3500fc1e11bd99029f",
- 15000000 to "77c0a6256b17d6fdfd0926312ab168c6ac7357b11e93933e31f2f5fd5aefd400",
- 16000000 to "28598fc683ac23a324e732ae398e093b5b80b03f01bdcf2f2d1b8e6bc76d183e",
- 16777216 to "50e72a0e26442fe2552dc3938ac58658228c0cbfb1d2ca872ae435266fcd055e",
- )
- val encoded = "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmno".encodeToUByteArray()
- for (roundsExpected in roundsExpectedMap) {
- val sha256 = Sha256Pure()
- for (i in 0 until roundsExpected.key) {
- sha256.update(encoded)
- }
- val result = sha256.digest()
- assertTrue("Failed on ${roundsExpected.key} rounds, expected ${roundsExpected.value}, but got result ${result.toHexString()}") {
- result.contentEquals(roundsExpected.value.hexStringToUByteArray())
- }
- }
-
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Test.kt
deleted file mode 100644
index 0378054..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512Test.kt
+++ /dev/null
@@ -1,72 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jul-2019
- */
-class Sha512Test {
-
-
- @Test
- fun testWellKnownValue() {
-
- val result = Sha512Pure.digest(inputMessage = "abc".encodeToByteArray().map { it.toUByte() }.toUByteArray())
- println(result.map {it.toString(16)})
- val expectedResult = "ddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a" +
- "2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
-
-
- }
-
-
-
- @Test
- fun testWellKnown3() {
- val sha512 = Sha512Pure()
- sha512.update(data = "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu")
- val resultDoubleBlock = sha512.digest()
- val expectedResultForDoubleBlock = "8e959b75dae313da8cf4f72814fc143f8f7779c6eb9f7fa17299aeadb6889018" +
- "501d289e4900f7e4331b99dec4b5433ac7d329eeb6dd26545e96e55b874be909"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun testWellKnownLong() {
- val inputBuilder = StringBuilder()
- for (i in 0 until 1000000) {
- inputBuilder.append("a")
- }
- val resultDoubleBlock = Sha512Pure.digest(inputMessage = (inputBuilder.toString()).encodeToByteArray().map { it.toUByte() }.toUByteArray())
- val expectedResultForDoubleBlock = "e718483d0ce769644e2e42c7bc15b4638e1f98b13b2044285632a803afa973ebde0ff244877ea60a4cb0432ce577c31beb009c5c2c49aa2e4eadb217ad8cc09b"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512UpdateableTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512UpdateableTest.kt
deleted file mode 100644
index 38aa37e..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/hash/sha/Sha512UpdateableTest.kt
+++ /dev/null
@@ -1,87 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.hash.sha
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import kotlin.test.Ignore
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Jul-2019
- */
-class Sha512UpdatableTest {
-
- @Test
- fun testWellKnownValue() {
- val sha512 = Sha512Pure()
- sha512.update("abc")
- val result = sha512.digest()
- val expectedResult = "ddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a" +
- "2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
-
-
- }
-
-
- @Test
- fun testWellKnownDoubleBlock() {
- val sha512 = Sha512Pure()
- sha512.update(data = "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu")
- val resultDoubleBlock = sha512.digest()
- println(resultDoubleBlock.map{ it.toString(16)}.joinToString(separator = ""))
- val expectedResultForDoubleBlock = "8e959b75dae313da8cf4f72814fc143f8f7779c6eb9f7fa17299aeadb6889018" +
- "501d289e4900f7e4331b99dec4b5433ac7d329eeb6dd26545e96e55b874be909"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-
-
- @Test
- fun testWellKnownLong() {
- val sha512 = Sha512Pure()
- for (i in 0 until 10000) {
- sha512.update("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa")
- }
- val resultDoubleBlock = sha512.digest()
- val expectedResultForDoubleBlock = "e718483d0ce769644e2e42c7bc15b4638e1f98b13b2044285632a803afa973ebde0ff244877ea60a4cb0432ce577c31beb009c5c2c49aa2e4eadb217ad8cc09b"
- assertTrue {
- resultDoubleBlock.contentEquals(expectedResultForDoubleBlock.hexStringToUByteArray())
- }
- }
-
-
- @Ignore // Takes too long on native and js, but it now finishes correctly (and surprisingly quickly) on JVM
- @Test
- fun testWellKnownLonger() {
- val sha512 = Sha512Pure()
- for (i in 0 until 16_777_216) {
- sha512.update("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmno")
- }
- val result = sha512.digest()
- val expectedResult = "b47c933421ea2db149ad6e10fce6c7f93d0752380180ffd7f4629a712134831d77be6091b819ed352c2967a2e2d4fa5050723c9630691f1a05a7281dbe6c1086"
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/highlevel/EncryptionTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/highlevel/EncryptionTest.kt
deleted file mode 100644
index d8f05da..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/highlevel/EncryptionTest.kt
+++ /dev/null
@@ -1,48 +0,0 @@
-package com.ionspin.kotlin.crypto.highlevel
-
-import com.ionspin.kotlin.crypto.Crypto
-import com.ionspin.kotlin.crypto.SymmetricKey
-import com.ionspin.kotlin.crypto.hash.decodeToString
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 09-Jul-2020
- */
-class EncryptionTest {
- @Test
- fun testMultipartEncryption() {
- val plaintext = ("pUoR4JVXJUeMKNkt6ZGGzEdTo33ajNGXwXpivBKA0XKs8toGRYI9Eul4bELRDkaQDNhd4vZseEFU" +
- "ojsAn3c9zIifIrMnydSivHVZ2pBtpAQwYoJhYmEsfE0tROGnOwFWyB9K6LRSv1gB3YqKR9VyM8mpRoUM3UCRRjyiX7bnKdCE1" +
- "EiX0myiwcY1nUKTgB3keERWtMU07hX7bCtao5nRvDofSj3o3IInHRQh6opltr5asQwn4m1qn029QF").encodeToUByteArray()
- plaintext.hexColumsPrint()
- val associatedData = "Additional data 1".encodeToUByteArray()
-// val associatedData = ubyteArrayOf()
- val keyValue = UByteArray(32) { it.toUByte() }
- val key = SymmetricKey(keyValue)
- val encryptor = Crypto.Encryption.createMultipartEncryptor(key)
- val header = encryptor.startEncryption()
- val ciphertext1 = encryptor.encryptPartialData(plaintext.sliceArray(0 until 100), associatedData)
- val ciphertext2 = encryptor.encryptPartialData(plaintext.sliceArray(100 until 200))
- val ciphertext3 = encryptor.encryptPartialData(plaintext.sliceArray(200 until 250))
- //decrypt
- val decryptor = Crypto.Encryption.createMultipartDecryptor(key, header)
- val plaintext1 = decryptor.decryptPartialData(ciphertext1, associatedData)
- val plaintext2 = decryptor.decryptPartialData(ciphertext2)
- val plaintext3 = decryptor.decryptPartialData(ciphertext3)
-
- val combinedPlaintext = plaintext1.data + plaintext2.data + plaintext3.data
-
- combinedPlaintext.hexColumsPrint()
- assertTrue {
- plaintext.contentEquals(combinedPlaintext)
- }
-
-
-
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/mac/Poly1305Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/mac/Poly1305Test.kt
deleted file mode 100644
index b24c72e..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/mac/Poly1305Test.kt
+++ /dev/null
@@ -1,224 +0,0 @@
-package com.ionspin.kotlin.crypto.mac
-
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 18-Jun-2020
- */
-class Poly1305Test {
-
- /**
- * From RFC7539
- */
- @Test
- fun testPoly1305() {
- assertTrue {
- val key = ubyteArrayOf(
- 0x85U, 0xd6U, 0xbeU, 0x78U, 0x57U, 0x55U, 0x6dU,
- 0x33U, 0x7fU, 0x44U, 0x52U, 0xfeU, 0x42U, 0xd5U,
- 0x06U, 0xa8U, 0x01U, 0x03U, 0x80U, 0x8aU, 0xfbU,
- 0x0dU, 0xb2U, 0xfdU, 0x4aU, 0xbfU, 0xf6U, 0xafU,
- 0x41U, 0x49U, 0xf5U, 0x1bU
- )
- val message = ubyteArrayOf(
- 0x43U, 0x72U, 0x79U, 0x70U, 0x74U, 0x6fU, 0x67U, 0x72U,
- 0x61U, 0x70U, 0x68U, 0x69U, 0x63U, 0x20U, 0x46U, 0x6fU,
- 0x72U, 0x75U, 0x6dU, 0x20U, 0x52U, 0x65U, 0x73U, 0x65U,
- 0x61U, 0x72U, 0x63U, 0x68U, 0x20U, 0x47U, 0x72U, 0x6fU,
- 0x75U, 0x70U
- )
- val expected = ubyteArrayOf(
- 0xA8U, 0x06U, 0x1DU, 0xC1U,
- 0x30U, 0x51U, 0x36U, 0xC6U,
- 0xC2U, 0x2BU, 0x8BU, 0xAFU,
- 0x0CU, 0x01U, 0x27U, 0xA9U,
- )
-
- val result =
- Poly1305.poly1305Authenticate(
- key,
- message,
- )
- expected.contentEquals(result)
- }
- assertTrue {
- val key = ubyteArrayOf(
- 0x85U, 0x1fU, 0xc4U, 0x0cU, 0x34U, 0x67U, 0xacU, 0x0bU,
- 0xe0U, 0x5cU, 0xc2U, 0x04U, 0x04U, 0xf3U, 0xf7U, 0x00U,
- 0x58U, 0x0bU, 0x3bU, 0x0fU, 0x94U, 0x47U, 0xbbU, 0x1eU,
- 0x69U, 0xd0U, 0x95U, 0xb5U, 0x92U, 0x8bU, 0x6dU, 0xbcU
- )
- val message = ubyteArrayOf(
- 0xf3U, 0xf6U
- )
- val expected = ubyteArrayOf(
- 0xf4U, 0xc6U, 0x33U, 0xc3U, 0x04U, 0x4fU, 0xc1U, 0x45U,
- 0xf8U, 0x4fU, 0x33U, 0x5cU, 0xb8U, 0x19U, 0x53U, 0xdeU
- )
-
- val result =
- Poly1305.poly1305Authenticate(
- key,
- message,
- )
- expected.contentEquals(result)
- }
-
- assertTrue {
- val key = ubyteArrayOf(
- 0x75U, 0xdeU, 0xaaU, 0x25U, 0xc0U, 0x9fU, 0x20U, 0x8eU,
- 0x1dU, 0xc4U, 0xceU, 0x6bU, 0x5cU, 0xadU, 0x3fU, 0xbfU,
- 0xddU, 0x3fU, 0xabU, 0x22U, 0x51U, 0xf1U, 0x1aU, 0xc7U,
- 0x59U, 0xf0U, 0x88U, 0x71U, 0x29U, 0xccU, 0x2eU, 0xe7U,
- )
- val message = ubyteArrayOf(
-
- )
- val expected = ubyteArrayOf(
- 0xddU, 0x3fU, 0xabU, 0x22U, 0x51U, 0xf1U, 0x1aU, 0xc7U,
- 0x59U, 0xf0U, 0x88U, 0x71U, 0x29U, 0xccU, 0x2eU, 0xe7U
- )
-
- val result =
- Poly1305.poly1305Authenticate(
- key,
- message,
- )
- expected.contentEquals(result)
- }
-
- assertTrue {
- val key = ubyteArrayOf(
- 0x12U, 0x97U, 0x6aU, 0x08U, 0xc4U, 0x42U, 0x6dU, 0x0cU,
- 0xe8U, 0xa8U, 0x24U, 0x07U, 0xc4U, 0xf4U, 0x82U, 0x07U,
- 0x80U, 0xf8U, 0xc2U, 0x0aU, 0xa7U, 0x12U, 0x02U, 0xd1U,
- 0xe2U, 0x91U, 0x79U, 0xcbU, 0xcbU, 0x55U, 0x5aU, 0x57U
- )
- val message = ubyteArrayOf(
- 0xabU, 0x08U, 0x12U, 0x72U, 0x4aU, 0x7fU, 0x1eU, 0x34U,
- 0x27U, 0x42U, 0xcbU, 0xedU, 0x37U, 0x4dU, 0x94U, 0xd1U,
- 0x36U, 0xc6U, 0xb8U, 0x79U, 0x5dU, 0x45U, 0xb3U, 0x81U,
- 0x98U, 0x30U, 0xf2U, 0xc0U, 0x44U, 0x91U, 0xfaU, 0xf0U,
- 0x99U, 0x0cU, 0x62U, 0xe4U, 0x8bU, 0x80U, 0x18U, 0xb2U,
- 0xc3U, 0xe4U, 0xa0U, 0xfaU, 0x31U, 0x34U, 0xcbU, 0x67U,
- 0xfaU, 0x83U, 0xe1U, 0x58U, 0xc9U, 0x94U, 0xd9U, 0x61U,
- 0xc4U, 0xcbU, 0x21U, 0x09U, 0x5cU, 0x1bU, 0xf9U,
- )
- val expected = ubyteArrayOf(
- 0x51U, 0x54U, 0xadU, 0x0dU, 0x2cU, 0xb2U, 0x6eU, 0x01U,
- 0x27U, 0x4fU, 0xc5U, 0x11U, 0x48U, 0x49U, 0x1fU, 0x1bU
- )
-
- val result =
- Poly1305.poly1305Authenticate(
- key,
- message,
- )
- expected.contentEquals(result)
- }
- }
-
- @Test
- fun testUpdateablePoly1305() {
- assertTrue {
- val key = ubyteArrayOf(
- 0x85U, 0xd6U, 0xbeU, 0x78U, 0x57U, 0x55U, 0x6dU,
- 0x33U, 0x7fU, 0x44U, 0x52U, 0xfeU, 0x42U, 0xd5U,
- 0x06U, 0xa8U, 0x01U, 0x03U, 0x80U, 0x8aU, 0xfbU,
- 0x0dU, 0xb2U, 0xfdU, 0x4aU, 0xbfU, 0xf6U, 0xafU,
- 0x41U, 0x49U, 0xf5U, 0x1bU
- )
- val message = ubyteArrayOf(
- 0x43U, 0x72U, 0x79U, 0x70U, 0x74U, 0x6fU, 0x67U, 0x72U,
- 0x61U, 0x70U, 0x68U, 0x69U, 0x63U, 0x20U, 0x46U, 0x6fU,
- 0x72U, 0x75U, 0x6dU, 0x20U, 0x52U, 0x65U, 0x73U, 0x65U,
- 0x61U, 0x72U, 0x63U, 0x68U, 0x20U, 0x47U, 0x72U, 0x6fU,
- 0x75U, 0x70U
- )
- val expected = ubyteArrayOf(
- 0xA8U, 0x06U, 0x1DU, 0xC1U,
- 0x30U, 0x51U, 0x36U, 0xC6U,
- 0xC2U, 0x2BU, 0x8BU, 0xAFU,
- 0x0CU, 0x01U, 0x27U, 0xA9U,
- )
- val poly = Poly1305(key)
- poly.updateMac(message.sliceArray(0 until 16))
- poly.updateMac(message.sliceArray(16 until 32))
- val result = poly.finalizeMac(message.sliceArray(32 until 34))
-
- expected.contentEquals(result)
- }
- assertTrue {
- val key = ubyteArrayOf(
- 0x85U, 0x1fU, 0xc4U, 0x0cU, 0x34U, 0x67U, 0xacU, 0x0bU,
- 0xe0U, 0x5cU, 0xc2U, 0x04U, 0x04U, 0xf3U, 0xf7U, 0x00U,
- 0x58U, 0x0bU, 0x3bU, 0x0fU, 0x94U, 0x47U, 0xbbU, 0x1eU,
- 0x69U, 0xd0U, 0x95U, 0xb5U, 0x92U, 0x8bU, 0x6dU, 0xbcU
- )
- val message = ubyteArrayOf(
- 0xf3U, 0xf6U
- )
- val expected = ubyteArrayOf(
- 0xf4U, 0xc6U, 0x33U, 0xc3U, 0x04U, 0x4fU, 0xc1U, 0x45U,
- 0xf8U, 0x4fU, 0x33U, 0x5cU, 0xb8U, 0x19U, 0x53U, 0xdeU
- )
-
- val poly = Poly1305(key)
- val result = poly.finalizeMac(message)
- expected.contentEquals(result)
- }
-
- assertTrue {
- val key = ubyteArrayOf(
- 0x75U, 0xdeU, 0xaaU, 0x25U, 0xc0U, 0x9fU, 0x20U, 0x8eU,
- 0x1dU, 0xc4U, 0xceU, 0x6bU, 0x5cU, 0xadU, 0x3fU, 0xbfU,
- 0xddU, 0x3fU, 0xabU, 0x22U, 0x51U, 0xf1U, 0x1aU, 0xc7U,
- 0x59U, 0xf0U, 0x88U, 0x71U, 0x29U, 0xccU, 0x2eU, 0xe7U,
- )
- val message = ubyteArrayOf(
-
- )
- val expected = ubyteArrayOf(
- 0xddU, 0x3fU, 0xabU, 0x22U, 0x51U, 0xf1U, 0x1aU, 0xc7U,
- 0x59U, 0xf0U, 0x88U, 0x71U, 0x29U, 0xccU, 0x2eU, 0xe7U
- )
-
- val poly = Poly1305(key)
- val result = poly.finalizeMac(message)
- expected.contentEquals(result)
- }
-
- assertTrue {
- val key = ubyteArrayOf(
- 0x12U, 0x97U, 0x6aU, 0x08U, 0xc4U, 0x42U, 0x6dU, 0x0cU,
- 0xe8U, 0xa8U, 0x24U, 0x07U, 0xc4U, 0xf4U, 0x82U, 0x07U,
- 0x80U, 0xf8U, 0xc2U, 0x0aU, 0xa7U, 0x12U, 0x02U, 0xd1U,
- 0xe2U, 0x91U, 0x79U, 0xcbU, 0xcbU, 0x55U, 0x5aU, 0x57U
- )
- val message = ubyteArrayOf(
- 0xabU, 0x08U, 0x12U, 0x72U, 0x4aU, 0x7fU, 0x1eU, 0x34U,
- 0x27U, 0x42U, 0xcbU, 0xedU, 0x37U, 0x4dU, 0x94U, 0xd1U,
- 0x36U, 0xc6U, 0xb8U, 0x79U, 0x5dU, 0x45U, 0xb3U, 0x81U,
- 0x98U, 0x30U, 0xf2U, 0xc0U, 0x44U, 0x91U, 0xfaU, 0xf0U,
- 0x99U, 0x0cU, 0x62U, 0xe4U, 0x8bU, 0x80U, 0x18U, 0xb2U,
- 0xc3U, 0xe4U, 0xa0U, 0xfaU, 0x31U, 0x34U, 0xcbU, 0x67U,
- 0xfaU, 0x83U, 0xe1U, 0x58U, 0xc9U, 0x94U, 0xd9U, 0x61U,
- 0xc4U, 0xcbU, 0x21U, 0x09U, 0x5cU, 0x1bU, 0xf9U,
- )
- val expected = ubyteArrayOf(
- 0x51U, 0x54U, 0xadU, 0x0dU, 0x2cU, 0xb2U, 0x6eU, 0x01U,
- 0x27U, 0x4fU, 0xc5U, 0x11U, 0x48U, 0x49U, 0x1fU, 0x1bU
- )
-
- val poly = Poly1305(key)
- poly.updateMac(message.sliceArray(0 until 16))
- poly.updateMac(message.sliceArray(16 until 32))
- poly.updateMac(message.sliceArray(32 until 48))
- val result = poly.finalizeMac(message.sliceArray(48 until 63))
- expected.contentEquals(result)
- }
- }
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCbcTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCbcTest.kt
deleted file mode 100644
index c84a345..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCbcTest.kt
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-
-class AesCbcTest {
-
- @Test
- fun testCbcEncryption() {
- assertTrue {
- val key = "4278b840fb44aaa757c1bf04acbe1a3e"
- val iv = "57f02a5c5339daeb0a2908a06ac6393f"
- val plaintext = "3c888bbbb1a8eb9f3e9b87acaad986c466e2f7071c83083b8a557971918850e5"
- val expectedCipherText = "479c89ec14bc98994e62b2c705b5014e" +
- "175bd7832e7e60a1e92aac568a861eb7" +
- "fc2dc2f4a527ce39f79c56b31432c779"
- val aesCbc =
- AesCbcPure(InternalAesKey.Aes128Key(key), mode = Mode.ENCRYPT, initializationVector = iv.hexStringToUByteArray())
- aesCbc.addData(plaintext.hexStringToUByteArray())
- val encrypted = aesCbc.encrypt()
- println("Encrypted: ${encrypted.encryptedData.toHexString()}")
-
- expectedCipherText == encrypted.encryptedData.toHexString() &&
- iv == encrypted.initializationVector.toHexString()
- }
-
-
-
- }
-
- @Test
- fun testEncryptionApi() {
- assertTrue {
- val keyString = "4278b840fb44aaa757c1bf04acbe1a3e"
- val key = InternalAesKey.Aes128Key(keyString)
-
- val plainText = "3c888bbbb1a8eb9f3e9b87acaad986c466e2f7071c83083b8a557971918850e5"
-
- val encryptedDataAndInitializationVector = AesCbcPure.encrypt(key, plainText.hexStringToUByteArray())
- val decrypted = AesCbcPure.decrypt(
- key,
- encryptedDataAndInitializationVector.encryptedData,
- encryptedDataAndInitializationVector.initializationVector
- )
- plainText == decrypted.toHexString()
- }
- }
-
- @Test
- fun testCbcDecryption() {
- assertTrue {
- val key = "4278b840fb44aaa757c1bf04acbe1a3e"
- val iv = "57f02a5c5339daeb0a2908a06ac6393f"
- val cipherText = "479c89ec14bc98994e62b2c705b5014e" +
- "175bd7832e7e60a1e92aac568a861eb7" +
- "fc2dc2f4a527ce39f79c56b31432c779"
- val expectedPlainText = "3c888bbbb1a8eb9f3e9b87acaad986c466e2f7071c83083b8a557971918850e5"
- val aesCbc =
- AesCbcPure(InternalAesKey.Aes128Key(key), mode = Mode.DECRYPT, initializationVector = iv.hexStringToUByteArray())
- aesCbc.addData(cipherText.hexStringToUByteArray())
- val decrypted = aesCbc.decrypt()
- println("Decrypted: ${decrypted.toHexString()}")
-
- expectedPlainText == decrypted.toHexString()
- }
-
-
-
- }
-
- @Test
- fun testDecryptionApi() {
- assertTrue {
- val key = "4278b840fb44aaa757c1bf04acbe1a3e"
- val iv = "57f02a5c5339daeb0a2908a06ac6393f"
- val cipherText = "479c89ec14bc98994e62b2c705b5014e" +
- "175bd7832e7e60a1e92aac568a861eb7" +
- "fc2dc2f4a527ce39f79c56b31432c779"
- val expectedPlainText = "3c888bbbb1a8eb9f3e9b87acaad986c466e2f7071c83083b8a557971918850e5"
- val decrypted = AesCbcPure.decrypt(InternalAesKey.Aes128Key(key), cipherText.hexStringToUByteArray(), iv.hexStringToUByteArray())
- println("Decrypted: ${decrypted.toHexString()}")
-
- expectedPlainText == decrypted.toHexString()
- }
- }
-
-
-
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCtrTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCtrTest.kt
deleted file mode 100644
index 457e59c..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesCtrTest.kt
+++ /dev/null
@@ -1,105 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-
-class AesCtrTest {
-
- @Test
- fun testCtrEncryption() {
- assertTrue {
- val key = "2b7e151628aed2a6abf7158809cf4f3c"
- val ic = "f0f1f2f3f4f5f6f7f8f9fafbfcfdfeff"
- val plaintext =
- "6bc1bee22e409f96e93d7e117393172aae2d8a571e03ac9c9eb76fac45af8e5130c81c46a35ce411e5fbc1191a0a52eff69f2445df4f9b17ad2b417be66c3710"
- val expectedCipherText =
- "874d6191b620e3261bef6864990db6ce9806f66b7970fdff8617187bb9fffdff5ae4df3edbd5d35e5b4f09020db03eab1e031dda2fbe03d1792170a0f3009cee"
- val aesCtr = AesCtrPure(InternalAesKey.Aes128Key(key), mode = Mode.ENCRYPT, initialCounter = ic.hexStringToUByteArray())
- aesCtr.addData(
- plaintext.hexStringToUByteArray()
- )
- val encrypted = aesCtr.encrypt()
- println("Encrypted: ${encrypted.encryptedData.toHexString()}")
-
- expectedCipherText == encrypted.encryptedData.toHexString() &&
- ic == encrypted.initialCounter.toHexString()
- }
-
- }
-
- @Test
- fun testEncryptionApi() {
- val keyString = "4278b840fb44aaa757c1bf04acbe1a3e"
- val key = InternalAesKey.Aes128Key(keyString)
- val plainText = "6bc1bee22e409f96e93d7e117393172aae2d8a571e03ac9c9eb76fac45af8e5130c81c46a35ce411e5fbc1191a0a52eff69f2445df4f9b17ad2b417be66c3710"
-
- val encryptedDataAndInitializationVector = AesCtrPure.encrypt(key, plainText.hexStringToUByteArray())
- val decrypted = AesCtrPure.decrypt(
- key,
- encryptedDataAndInitializationVector.encryptedData,
- encryptedDataAndInitializationVector.initialCounter
- )
- assertTrue {
- plainText == decrypted.toHexString()
- }
- }
-
- @Test
- fun testCtrDecryption() {
- assertTrue {
- val key = "2b7e151628aed2a6abf7158809cf4f3c"
- val ic = "f0f1f2f3f4f5f6f7f8f9fafbfcfdfeff"
- val cipherText =
- "874d6191b620e3261bef6864990db6ce9806f66b7970fdff8617187bb9fffdff5ae4df3edbd5d35e5b4f09020db03eab1e031dda2fbe03d1792170a0f3009cee"
- val expectedPlainText =
- "6bc1bee22e409f96e93d7e117393172aae2d8a571e03ac9c9eb76fac45af8e5130c81c46a35ce411e5fbc1191a0a52eff69f2445df4f9b17ad2b417be66c3710"
- val aesCtr = AesCtrPure(InternalAesKey.Aes128Key(key), mode = Mode.DECRYPT, initialCounter = ic.hexStringToUByteArray())
- aesCtr.addData(cipherText.hexStringToUByteArray())
- val decrypted = aesCtr.decrypt()
- println("Decrypted: ${decrypted.toHexString()}")
- expectedPlainText == decrypted.toHexString()
- }
-
-
-
- }
-
- @Test
- fun testCtrDecryptionApi() {
- assertTrue {
- val key = "2b7e151628aed2a6abf7158809cf4f3c"
- val ic = "f0f1f2f3f4f5f6f7f8f9fafbfcfdfeff"
- val cipherText =
- "874d6191b620e3261bef6864990db6ce9806f66b7970fdff8617187bb9fffdff5ae4df3edbd5d35e5b4f09020db03eab1e031dda2fbe03d1792170a0f3009cee"
- val expectedPlainText =
- "6bc1bee22e409f96e93d7e117393172aae2d8a571e03ac9c9eb76fac45af8e5130c81c46a35ce411e5fbc1191a0a52eff69f2445df4f9b17ad2b417be66c3710"
- val decrypted = AesCtrPure.decrypt(InternalAesKey.Aes128Key(key), cipherText.hexStringToUByteArray(), ic.hexStringToUByteArray())
- println("Decrypted: ${decrypted.toHexString()}")
- expectedPlainText == decrypted.toHexString()
- }
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesTest.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesTest.kt
deleted file mode 100644
index be3bbd8..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/AesTest.kt
+++ /dev/null
@@ -1,270 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic (jovanovic.ugljesa@gmail.com) on 10/Sep/2019
- */
-
-class AesTest {
-
- val irrelevantKey = "01234567890123345678901234567890"
- val irrelevantInput = UByteArray(16) { 0U }
-
- @Test
- fun testSubBytes() {
- val fakeState = arrayOf(
- ubyteArrayOf(0x53U, 0U, 0U, 0U),
- ubyteArrayOf(0U, 0U, 0U, 0U),
- ubyteArrayOf(0U, 0U, 0U, 0U),
- ubyteArrayOf(0U, 0U, 0U, 0U)
- )
- val aes = AesPure(InternalAesKey.Aes128Key(irrelevantKey), irrelevantInput)
- fakeState.copyInto(aes.state)
- aes.subBytes()
- assertTrue {
- aes.state[0][0] == 0xEDU.toUByte()
- }
- }
-
- @Test
- fun testShiftRows() {
- val fakeState = arrayOf(
- ubyteArrayOf(0U, 1U, 2U, 3U),
- ubyteArrayOf(0U, 1U, 2U, 3U),
- ubyteArrayOf(0U, 1U, 2U, 3U),
- ubyteArrayOf(0U, 1U, 2U, 3U)
- )
- val expectedState = arrayOf(
- ubyteArrayOf(0U, 1U, 2U, 3U),
- ubyteArrayOf(1U, 2U, 3U, 0U),
- ubyteArrayOf(2U, 3U, 0U, 1U),
- ubyteArrayOf(3U, 0U, 1U, 2U)
- )
- val aes = AesPure(InternalAesKey.Aes128Key(irrelevantKey), irrelevantInput)
- fakeState.copyInto(aes.state)
- aes.shiftRows()
- assertTrue {
- aes.state.contentDeepEquals(expectedState)
- }
- }
-
- @Test
- fun testGaloisMultiply() {
- //Samples from FIPS-197
- assertTrue {
- val a = 0x57U
- val b = 0x83U
- val aes = AesPure(InternalAesKey.Aes128Key(irrelevantKey), irrelevantInput)
- val c = aes.galoisFieldMultiply(a.toUByte(), b.toUByte())
- c == 0xC1U.toUByte()
- }
-
- assertTrue {
- val a = 0x57U
- val b = 0x13U
- val aes = AesPure(InternalAesKey.Aes128Key(irrelevantKey), irrelevantInput)
- val c = aes.galoisFieldMultiply(a.toUByte(), b.toUByte())
- c == 0xFEU.toUByte()
- }
-
-
- }
-
- @Test
- fun testMixColumns() {
- //Test vectors from wikipedia
- val fakeState = arrayOf(
- ubyteArrayOf(0xdbU, 0xf2U, 0x01U, 0xc6U),
- ubyteArrayOf(0x13U, 0x0aU, 0x01U, 0xc6U),
- ubyteArrayOf(0x53U, 0x22U, 0x01U, 0xc6U),
- ubyteArrayOf(0x45U, 0x5cU, 0x01U, 0xc6U)
- )
-
- val expectedState = arrayOf(
- ubyteArrayOf(0x8eU, 0x9fU, 0x01U, 0xc6U),
- ubyteArrayOf(0x4dU, 0xdcU, 0x01U, 0xc6U),
- ubyteArrayOf(0xa1U, 0x58U, 0x01U, 0xc6U),
- ubyteArrayOf(0xbcU, 0x9dU, 0x01U, 0xc6U)
- )
-
- val aes = AesPure(InternalAesKey.Aes128Key(irrelevantKey), irrelevantInput)
- fakeState.copyInto(aes.state)
- aes.mixColumns()
- assertTrue {
- aes.state.contentDeepEquals(expectedState)
- }
-
- }
-
- @Test
- fun testKeyExpansion() {
- assertTrue {
- val key = "2b7e151628aed2a6abf7158809cf4f3c"
- val expectedExpandedKey = uintArrayOf(
- // @formatter:off
- 0x2b7e1516U, 0x28aed2a6U, 0xabf71588U, 0x09cf4f3cU, 0xa0fafe17U, 0x88542cb1U,
- 0x23a33939U, 0x2a6c7605U, 0xf2c295f2U, 0x7a96b943U, 0x5935807aU, 0x7359f67fU,
- 0x3d80477dU, 0x4716fe3eU, 0x1e237e44U, 0x6d7a883bU, 0xef44a541U, 0xa8525b7fU,
- 0xb671253bU, 0xdb0bad00U, 0xd4d1c6f8U, 0x7c839d87U, 0xcaf2b8bcU, 0x11f915bcU,
- 0x6d88a37aU, 0x110b3efdU, 0xdbf98641U, 0xca0093fdU, 0x4e54f70eU, 0x5f5fc9f3U,
- 0x84a64fb2U, 0x4ea6dc4fU, 0xead27321U, 0xb58dbad2U, 0x312bf560U, 0x7f8d292fU,
- 0xac7766f3U, 0x19fadc21U, 0x28d12941U, 0x575c006eU, 0xd014f9a8U, 0xc9ee2589U,
- 0xe13f0cc8U, 0xb6630ca6U
- // @formatter:on
- ).toTypedArray()
-
-
- val aes = AesPure(InternalAesKey.Aes128Key(key), irrelevantInput)
- val result = aes.expandedKey.map {
- it.foldIndexed(0U) { index, acc, uByte ->
- acc + (uByte.toUInt() shl (24 - index * 8))
- }
- }.toTypedArray()
- expectedExpandedKey.contentEquals(result)
- }
-
- assertTrue {
- val key = "8e73b0f7da0e6452c810f32b809079e562f8ead2522c6b7b"
- val expectedExpandedKey = uintArrayOf(
- // @formatter:off
- 0x8e73b0f7U, 0xda0e6452U, 0xc810f32bU, 0x809079e5U, 0x62f8ead2U, 0x522c6b7bU,
- 0xfe0c91f7U, 0x2402f5a5U, 0xec12068eU, 0x6c827f6bU, 0x0e7a95b9U, 0x5c56fec2U, 0x4db7b4bdU, 0x69b54118U,
- 0x85a74796U, 0xe92538fdU, 0xe75fad44U, 0xbb095386U, 0x485af057U, 0x21efb14fU, 0xa448f6d9U, 0x4d6dce24U,
- 0xaa326360U, 0x113b30e6U, 0xa25e7ed5U, 0x83b1cf9aU, 0x27f93943U, 0x6a94f767U, 0xc0a69407U, 0xd19da4e1U,
- 0xec1786ebU, 0x6fa64971U, 0x485f7032U, 0x22cb8755U, 0xe26d1352U, 0x33f0b7b3U, 0x40beeb28U, 0x2f18a259U,
- 0x6747d26bU, 0x458c553eU, 0xa7e1466cU, 0x9411f1dfU, 0x821f750aU, 0xad07d753U, 0xca400538U, 0x8fcc5006U,
- 0x282d166aU, 0xbc3ce7b5U, 0xe98ba06fU, 0x448c773cU, 0x8ecc7204U, 0x01002202U
- // @formatter:on
- ).toTypedArray()
-
-
- val aes = AesPure(InternalAesKey.Aes192Key(key), irrelevantInput)
- val result = aes.expandedKey.map {
- it.foldIndexed(0U) { index, acc, uByte ->
- acc + (uByte.toUInt() shl (24 - index * 8))
- }
- }.toTypedArray()
- expectedExpandedKey.contentEquals(result)
- }
-
- assertTrue {
- val key = "603deb1015ca71be2b73aef0857d77811f352c073b6108d72d9810a30914dff4"
-
- val expectedExpandedKey = uintArrayOf(
- // @formatter:off
- 0x603deb10U, 0x15ca71beU, 0x2b73aef0U, 0x857d7781U, 0x1f352c07U, 0x3b6108d7U, 0x2d9810a3U, 0x0914dff4U,
- 0x9ba35411U, 0x8e6925afU, 0xa51a8b5fU, 0x2067fcdeU, 0xa8b09c1aU, 0x93d194cdU, 0xbe49846eU, 0xb75d5b9aU,
- 0xd59aecb8U, 0x5bf3c917U, 0xfee94248U, 0xde8ebe96U, 0xb5a9328aU, 0x2678a647U, 0x98312229U, 0x2f6c79b3U,
- 0x812c81adU, 0xdadf48baU, 0x24360af2U, 0xfab8b464U, 0x98c5bfc9U, 0xbebd198eU, 0x268c3ba7U, 0x09e04214U,
- 0x68007bacU, 0xb2df3316U, 0x96e939e4U, 0x6c518d80U, 0xc814e204U, 0x76a9fb8aU, 0x5025c02dU, 0x59c58239U,
- 0xde136967U, 0x6ccc5a71U, 0xfa256395U, 0x9674ee15U, 0x5886ca5dU, 0x2e2f31d7U, 0x7e0af1faU, 0x27cf73c3U,
- 0x749c47abU, 0x18501ddaU, 0xe2757e4fU, 0x7401905aU, 0xcafaaae3U, 0xe4d59b34U, 0x9adf6aceU, 0xbd10190dU,
- 0xfe4890d1U, 0xe6188d0bU, 0x046df344U, 0x706c631eU
- // @formatter:on
- ).toTypedArray()
-
-
- val aes = AesPure(InternalAesKey.Aes256Key(key), irrelevantInput)
- val result = aes.expandedKey.map {
- it.foldIndexed(0U) { index, acc, uByte ->
- acc + (uByte.toUInt() shl (24 - index * 8))
- }
- }.toTypedArray()
- expectedExpandedKey.contentEquals(result)
- }
-
- }
-
- @Test
- fun testEncryption() {
- val input = "3243f6a8885a308d313198a2e0370734"
- val key = "2b7e151628aed2a6abf7158809cf4f3c"
- val expectedResult = "3925841d02dc09fbdc118597196a0b32"
-
- val aes = AesPure(InternalAesKey.Aes128Key(key), input.hexStringToUByteArray())
- val result = aes.encrypt()
- assertTrue {
- result.contentEquals(expectedResult.hexStringToUByteArray())
- }
- }
-
- @Test
- fun testEncryptionAndDecryption() {
- assertTrue {
- val input = "3243f6a8885a308d313198a2e0370734"
- val key = "2b7e151628aed2a6abf7158809cf4f3c"
- val expectedResult = "3925841d02dc09fbdc118597196a0b32"
- val original = input.hexStringToUByteArray()
- val aes = AesPure(InternalAesKey.Aes128Key(key), original)
- val encrypted = aes.encrypt()
- assertTrue {
- encrypted.contentEquals(expectedResult.hexStringToUByteArray())
- }
- val decrypted = AesPure.decrypt(InternalAesKey.Aes128Key(key), encrypted)
-
- decrypted.contentEquals(original)
- }
- assertTrue {
- val input = "00112233445566778899aabbccddeeff"
- val key = "000102030405060708090a0b0c0d0e0f"
- val expectedResult = "69c4e0d86a7b0430d8cdb78070b4c55a"
- val original = input.hexStringToUByteArray()
- val aes = AesPure(InternalAesKey.Aes128Key(key), original)
- val encrypted = aes.encrypt()
- assertTrue {
- encrypted.contentEquals(expectedResult.hexStringToUByteArray())
- }
- val aesDec = AesPure(InternalAesKey.Aes128Key(key), encrypted)
- val decrypted = aesDec.decrypt()
- assertTrue {
- aesDec.expandedKey.contentDeepEquals(aes.expandedKey)
- }
- decrypted.contentEquals(original)
- }
-
- assertTrue {
- val input = "00112233445566778899aabbccddeeff"
- val key = "000102030405060708090a0b0c0d0e0f"
- val expectedResult = "69c4e0d86a7b0430d8cdb78070b4c55a"
- val original = input.hexStringToUByteArray()
- val encrypted = AesPure.encrypt(InternalAesKey.Aes128Key(key), original)
- assertTrue {
- encrypted.contentEquals(expectedResult.hexStringToUByteArray())
- }
- val decrypted = AesPure.decrypt(InternalAesKey.Aes128Key(key), encrypted)
- decrypted.contentEquals(original)
- }
-
- assertTrue {
- val input = "00112233445566778899aabbccddeeff"
- val key = "000102030405060708090a0b0c0d0e0f1011121314151617"
- val expectedResult = "dda97ca4864cdfe06eaf70a0ec0d7191"
- val original = input.hexStringToUByteArray()
- val encrypted = AesPure.encrypt(InternalAesKey.Aes192Key(key), original)
- assertTrue {
- encrypted.contentEquals(expectedResult.hexStringToUByteArray())
- }
- val decrypted = AesPure.decrypt(InternalAesKey.Aes192Key(key), encrypted)
- decrypted.contentEquals(original)
- }
-
- assertTrue {
- val input = "00112233445566778899aabbccddeeff"
- val key = "000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f"
- val expectedResult = "8ea2b7ca516745bfeafc49904b496089"
- val original = input.hexStringToUByteArray()
- val encrypted = AesPure.encrypt(InternalAesKey.Aes256Key(key), original)
- assertTrue {
- encrypted.contentEquals(expectedResult.hexStringToUByteArray())
- }
- val decrypted = AesPure.decrypt(InternalAesKey.Aes256Key(key), encrypted)
- decrypted.contentEquals(original)
- }
- }
-
-
-
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/ChaCha20Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/ChaCha20Test.kt
deleted file mode 100644
index 4687643..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/ChaCha20Test.kt
+++ /dev/null
@@ -1,90 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-Jun-2020
- */
-class ChaCha20Test {
-
-
- @Test
- fun testQuarterRound() {
- val a = 0x11111111U
- val b = 0x01020304U
- val c = 0x9b8d6f43U
- val d = 0x01234567U
- val input = uintArrayOf(a, b, c, d)
- val aExpected = 0xea2a92f4U
- val bExpected = 0xcb1cf8ceU
- val cExpected = 0x4581472eU
- val dExpected = 0x5881c4bbU
- val expected = uintArrayOf(aExpected, bExpected, cExpected, dExpected)
- ChaCha20Pure.quarterRound(input, 0, 1, 2, 3)
- assertTrue {
- input.contentEquals(expected)
- }
- }
-
- @Test
- fun testBlockFunction() {
- //From RFC 7539
- val state = uintArrayOf(
- 0x61707865U, 0x3320646eU, 0x79622d32U, 0x6b206574U,
- 0x03020100U, 0x07060504U, 0x0b0a0908U, 0x0f0e0d0cU,
- 0x13121110U, 0x17161514U, 0x1b1a1918U, 0x1f1e1d1cU,
- 0x00000001U, 0x09000000U, 0x4a000000U, 0x00000000U,
- )
- val expected = ubyteArrayOf(
- 0x10U, 0xf1U, 0xe7U, 0xe4U, 0xd1U, 0x3bU, 0x59U, 0x15U, 0x50U, 0x0fU, 0xddU, 0x1fU, 0xa3U, 0x20U, 0x71U, 0xc4U,
- 0xc7U, 0xd1U, 0xf4U, 0xc7U, 0x33U, 0xc0U, 0x68U, 0x03U, 0x04U, 0x22U, 0xaaU, 0x9aU, 0xc3U, 0xd4U, 0x6cU, 0x4eU,
- 0xd2U, 0x82U, 0x64U, 0x46U, 0x07U, 0x9fU, 0xaaU, 0x09U, 0x14U, 0xc2U, 0xd7U, 0x05U, 0xd9U, 0x8bU, 0x02U, 0xa2U,
- 0xb5U, 0x12U, 0x9cU, 0xd1U, 0xdeU, 0x16U, 0x4eU, 0xb9U, 0xcbU, 0xd0U, 0x83U, 0xe8U, 0xa2U, 0x50U, 0x3cU, 0x4eU
- )
- val result = ChaCha20Pure.hash(state)
- assertTrue {
- expected.contentEquals(result)
- }
- }
-
- @Test
- fun testEncryption() {
-
- //From RFC 7539
- val key = ubyteArrayOf(
- 0x00U, 0x01U, 0x02U, 0x03U, 0x04U, 0x05U,
- 0x06U, 0x07U, 0x08U, 0x09U, 0x0aU, 0x0bU,
- 0x0cU, 0x0dU, 0x0eU, 0x0fU, 0x10U, 0x11U,
- 0x12U, 0x13U, 0x14U, 0x15U, 0x16U, 0x17U,
- 0x18U, 0x19U, 0x1aU, 0x1bU, 0x1cU, 0x1dU,
- 0x1eU, 0x1fU
- )
- val nonce = ubyteArrayOf(
- 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x00U, 0x4aU, 0x00U, 0x00U, 0x00U, 0x00U
- )
- val message =
- "Ladies and Gentlemen of the class of '99: If I could offer you only one tip for the future, sunscreen would be it.".encodeToUByteArray()
- val expected = ubyteArrayOf(
- 0x6eU, 0x2eU, 0x35U, 0x9aU, 0x25U, 0x68U, 0xf9U, 0x80U, 0x41U, 0xbaU, 0x07U, 0x28U, 0xddU, 0x0dU, 0x69U, 0x81U,
- 0xe9U, 0x7eU, 0x7aU, 0xecU, 0x1dU, 0x43U, 0x60U, 0xc2U, 0x0aU, 0x27U, 0xafU, 0xccU, 0xfdU, 0x9fU, 0xaeU, 0x0bU,
- 0xf9U, 0x1bU, 0x65U, 0xc5U, 0x52U, 0x47U, 0x33U, 0xabU, 0x8fU, 0x59U, 0x3dU, 0xabU, 0xcdU, 0x62U, 0xb3U, 0x57U,
- 0x16U, 0x39U, 0xd6U, 0x24U, 0xe6U, 0x51U, 0x52U, 0xabU, 0x8fU, 0x53U, 0x0cU, 0x35U, 0x9fU, 0x08U, 0x61U, 0xd8U,
- 0x07U, 0xcaU, 0x0dU, 0xbfU, 0x50U, 0x0dU, 0x6aU, 0x61U, 0x56U, 0xa3U, 0x8eU, 0x08U, 0x8aU, 0x22U, 0xb6U, 0x5eU,
- 0x52U, 0xbcU, 0x51U, 0x4dU, 0x16U, 0xccU, 0xf8U, 0x06U, 0x81U, 0x8cU, 0xe9U, 0x1aU, 0xb7U, 0x79U, 0x37U, 0x36U,
- 0x5aU, 0xf9U, 0x0bU, 0xbfU, 0x74U, 0xa3U, 0x5bU, 0xe6U, 0xb4U, 0x0bU, 0x8eU, 0xedU, 0xf2U, 0x78U, 0x5eU, 0x42U,
- 0x87U, 0x4dU,
- )
- val result = ChaCha20Pure.xorWithKeystream(key, nonce, message, 1U)
- assertTrue {
- expected.contentEquals(result)
- }
-
-
- }
-
-
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/Salsa20Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/Salsa20Test.kt
deleted file mode 100644
index 051722f..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/Salsa20Test.kt
+++ /dev/null
@@ -1,395 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.symmetric.LatinDancesCommon.littleEndian
-import com.ionspin.kotlin.crypto.symmetric.LatinDancesCommon.littleEndianInverted
-import com.ionspin.kotlin.crypto.util.fromLittleEndianToUInt
-import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
-import com.ionspin.kotlin.crypto.util.rotateLeft
-import com.ionspin.kotlin.crypto.util.toHexString
-import kotlin.test.Test
-import kotlin.test.assertEquals
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 14-Jun-2020
- */
-class Salsa20Test {
-
- @Test
- fun testRotateLeft() {
- val a = 0xc0a8787eU
- val b = a rotateLeft 5
- val expected = 0x150f0fd8U
- assertEquals(b, expected)
- }
-
- @Test
- fun testQuarterRound() {
- assertTrue {
- val input = uintArrayOf(0U, 0U, 0U, 0U)
- val expected = uintArrayOf(0U, 0U, 0U, 0U)
- Salsa20Pure.quarterRound(input, 0, 1, 2, 3)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
-
- expected.contentEquals(input)
- }
-
- assertTrue {
- val input = uintArrayOf(1U, 0U, 0U, 0U)
- val expected = uintArrayOf(0x08008145U, 0x00000080U, 0x00010200U, 0x20500000U)
- Salsa20Pure.quarterRound(input, 0, 1, 2, 3)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
-
- expected.contentEquals(input)
- }
-
- assertTrue {
- val input = uintArrayOf(0U, 1U, 0U, 0U)
- val expected = uintArrayOf(0x88000100U, 0x00000001U, 0x00000200U, 0x00402000U)
- Salsa20Pure.quarterRound(input, 0, 1, 2, 3)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
-
- expected.contentEquals(input)
- }
-
- assertTrue {
- val input = uintArrayOf(0U, 0U, 1U, 0U)
- val expected = uintArrayOf(0x80040000U, 0x00000000U, 0x00000001U, 0x00002000U)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- Salsa20Pure.quarterRound(input, 0, 1, 2, 3)
- expected.contentEquals(input)
- }
-
- assertTrue {
- val input = uintArrayOf(0U, 0U, 0U, 1U)
- val expected = uintArrayOf(0x00048044U, 0x00000080U, 0x00010000U, 0x20100001U)
- Salsa20Pure.quarterRound(input, 0, 1, 2, 3)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
-
- expected.contentEquals(input)
- }
-
-
- assertTrue {
- val input = uintArrayOf(0xd3917c5bU, 0x55f1c407U, 0x52a58a7aU, 0x8f887a3bU)
- val expected = uintArrayOf(0x3e2f308cU, 0xd90a8f36U, 0x6ab2a923U, 0x2883524cU)
- Salsa20Pure.quarterRound(input, 0, 1, 2, 3)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- expected.contentEquals(input)
- }
- }
-
- @Test
- fun testRowRound() {
- assertTrue {
- val input = uintArrayOf(
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U
- )
- val expected = uintArrayOf(
- 0x08008145U, 0x00000080U, 0x00010200U, 0x20500000U,
- 0x20100001U, 0x00048044U, 0x00000080U, 0x00010000U,
- 0x00000001U, 0x00002000U, 0x80040000U, 0x00000000U,
- 0x00000001U, 0x00000200U, 0x00402000U, 0x88000100U
- )
-
- Salsa20Pure.rowRound(input)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- expected.contentEquals(input)
- }
- assertTrue {
-
- val input = uintArrayOf(
- 0x08521bd6U, 0x1fe88837U, 0xbb2aa576U, 0x3aa26365U,
- 0xc54c6a5bU, 0x2fc74c2fU, 0x6dd39cc3U, 0xda0a64f6U,
- 0x90a2f23dU, 0x067f95a6U, 0x06b35f61U, 0x41e4732eU,
- 0xe859c100U, 0xea4d84b7U, 0x0f619bffU, 0xbc6e965aU
- )
- val expected = uintArrayOf(
- 0xa890d39dU, 0x65d71596U, 0xe9487daaU, 0xc8ca6a86U,
- 0x949d2192U, 0x764b7754U, 0xe408d9b9U, 0x7a41b4d1U,
- 0x3402e183U, 0x3c3af432U, 0x50669f96U, 0xd89ef0a8U,
- 0x0040ede5U, 0xb545fbceU, 0xd257ed4fU, 0x1818882dU
- )
- Salsa20Pure.rowRound(input)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- expected.contentEquals(input)
- }
- }
-
- @Test
- fun testColumnRound() {
- assertTrue {
- val input = uintArrayOf(
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U
- )
- val expected = uintArrayOf(
- 0x10090288U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000101U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00020401U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x40a04001U, 0x00000000U, 0x00000000U, 0x00000000U
- )
-
- Salsa20Pure.columnRound(input)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- expected.contentEquals(input)
- }
- assertTrue {
-
- val input = uintArrayOf(
- 0x08521bd6U, 0x1fe88837U, 0xbb2aa576U, 0x3aa26365U,
- 0xc54c6a5bU, 0x2fc74c2fU, 0x6dd39cc3U, 0xda0a64f6U,
- 0x90a2f23dU, 0x067f95a6U, 0x06b35f61U, 0x41e4732eU,
- 0xe859c100U, 0xea4d84b7U, 0x0f619bffU, 0xbc6e965aU
- )
- val expected = uintArrayOf(
- 0x8c9d190aU, 0xce8e4c90U, 0x1ef8e9d3U, 0x1326a71aU,
- 0x90a20123U, 0xead3c4f3U, 0x63a091a0U, 0xf0708d69U,
- 0x789b010cU, 0xd195a681U, 0xeb7d5504U, 0xa774135cU,
- 0x481c2027U, 0x53a8e4b5U, 0x4c1f89c5U, 0x3f78c9c8U
- )
- Salsa20Pure.columnRound(input)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- expected.contentEquals(input)
- }
- }
-
- @Test
- fun testDoubleRound() {
- assertTrue {
- val input = uintArrayOf(
- 0x00000001U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000000U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000000U, 0x00000000U, 0x00000000U, 0x00000000U,
- 0x00000000U, 0x00000000U, 0x00000000U, 0x00000000U
- )
- val expected = uintArrayOf(
- 0x8186a22dU, 0x0040a284U, 0x82479210U, 0x06929051U,
- 0x08000090U, 0x02402200U, 0x00004000U, 0x00800000U,
- 0x00010200U, 0x20400000U, 0x08008104U, 0x00000000U,
- 0x20500000U, 0xa0000040U, 0x0008180aU, 0x612a8020U
- )
-
- Salsa20Pure.doubleRound(input)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- expected.contentEquals(input)
- }
- assertTrue {
-
- val input = uintArrayOf(
- 0xde501066U, 0x6f9eb8f7U, 0xe4fbbd9bU, 0x454e3f57U,
- 0xb75540d3U, 0x43e93a4cU, 0x3a6f2aa0U, 0x726d6b36U,
- 0x9243f484U, 0x9145d1e8U, 0x4fa9d247U, 0xdc8dee11U,
- 0x054bf545U, 0x254dd653U, 0xd9421b6dU, 0x67b276c1U
- )
- val expected = uintArrayOf(
- 0xccaaf672U, 0x23d960f7U, 0x9153e63aU, 0xcd9a60d0U,
- 0x50440492U, 0xf07cad19U, 0xae344aa0U, 0xdf4cfdfcU,
- 0xca531c29U, 0x8e7943dbU, 0xac1680cdU, 0xd503ca00U,
- 0xa74b2ad6U, 0xbc331c5cU, 0x1dda24c7U, 0xee928277U
- )
- Salsa20Pure.doubleRound(input)
- println("Result ${input.joinToString { it.toString(16).padStart(2, '0') }}")
- expected.contentEquals(input)
- }
- }
-
- @Test
- fun littleEndianTest() {
- assertTrue {
- val input = ubyteArrayOf(86U, 75U, 30U, 9U)
- val expected = 0x091e4b56U
- val result = littleEndian(input, 0, 1, 2, 3)
- result == expected
- }
-
- assertTrue {
- val input = ubyteArrayOf(255U, 255U, 255U, 250U)
- val expected = 0xFAFFFFFFU
- val result = littleEndian(input, 0, 1, 2, 3)
- result == expected
- }
- }
-
- @Test
- fun littleEndianInvertedArrayTest() {
- assertTrue {
- val expected = ubyteArrayOf(86U, 75U, 30U, 9U)
- val input = uintArrayOf(0x091e4b56U)
- val result = UByteArray(4)
- littleEndianInverted(input, 0, result, 0)
- result.contentEquals(expected)
- }
-
- assertTrue {
- val expected = ubyteArrayOf(255U, 255U, 255U, 250U)
- val input = uintArrayOf(0xFAFFFFFFU)
- val result = UByteArray(4)
- littleEndianInverted(input, 0, result, 0)
- result.contentEquals(expected)
- }
- }
-
- @Test
- fun littleEndianInvertedTest() {
- assertTrue {
- val expected = ubyteArrayOf(86U, 75U, 30U, 9U)
- val input = 0x091e4b56U
- val result = UByteArray(4)
- littleEndianInverted(input, result, 0)
- result.contentEquals(expected)
- }
-
- assertTrue {
- val expected = ubyteArrayOf(255U, 255U, 255U, 250U)
- val input = 0xFAFFFFFFU
- val result = UByteArray(4)
- littleEndianInverted(input, result, 0)
- result.contentEquals(expected)
- }
- }
-
- @Test
- fun salsa20HashTest() {
- assertTrue {
- val input = ubyteArrayOf(
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U,
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U,
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U,
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U
- )
- val expected = ubyteArrayOf(
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U,
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U,
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U,
- 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U
- )
- val result = Salsa20Pure.hash(input.fromLittleEndianToUInt())
- input.contentEquals(expected)
- }
-
- assertTrue {
- val input = ubyteArrayOf(
- 211U, 159U, 13U, 115U, 76U, 55U, 82U, 183U, 3U, 117U, 222U, 37U, 191U, 187U, 234U, 136U,
- 49U, 237U, 179U, 48U, 1U, 106U, 178U, 219U, 175U, 199U, 166U, 48U, 86U, 16U, 179U, 207U,
- 31U, 240U, 32U, 63U, 15U, 83U, 93U, 161U, 116U, 147U, 48U, 113U, 238U, 55U, 204U, 36U,
- 79U, 201U, 235U, 79U, 3U, 81U, 156U, 47U, 203U, 26U, 244U, 243U, 88U, 118U, 104U, 54U
- )
- val expected = ubyteArrayOf(
- 109U, 42U, 178U, 168U, 156U, 240U, 248U, 238U, 168U, 196U, 190U, 203U, 26U, 110U, 170U, 154U,
- 29U, 29U, 150U, 26U, 150U, 30U, 235U, 249U, 190U, 163U, 251U, 48U, 69U, 144U, 51U, 57U,
- 118U, 40U, 152U, 157U, 180U, 57U, 27U, 94U, 107U, 42U, 236U, 35U, 27U, 111U, 114U, 114U,
- 219U, 236U, 232U, 135U, 111U, 155U, 110U, 18U, 24U, 232U, 95U, 158U, 179U, 19U, 48U, 202U
- )
- val result = Salsa20Pure.hash(input.fromLittleEndianToUInt())
- result.contentEquals(expected)
- }
-
- assertTrue {
- val input = ubyteArrayOf(
- 6U, 124U, 83U, 146U, 38U, 191U, 9U, 50U, 4U, 161U, 47U, 222U, 122U, 182U, 223U, 185U,
- 75U, 27U, 0U, 216U, 16U, 122U, 7U, 89U, 162U, 104U, 101U, 147U, 213U, 21U, 54U, 95U,
- 225U, 253U, 139U, 176U, 105U, 132U, 23U, 116U, 76U, 41U, 176U, 207U, 221U, 34U, 157U, 108U,
- 94U, 94U, 99U, 52U, 90U, 117U, 91U, 220U, 146U, 190U, 239U, 143U, 196U, 176U, 130U, 186U
- )
- val expected = ubyteArrayOf(
- 8U, 18U, 38U, 199U, 119U, 76U, 215U, 67U, 173U, 127U, 144U, 162U, 103U, 212U, 176U, 217U,
- 192U, 19U, 233U, 33U, 159U, 197U, 154U, 160U, 128U, 243U, 219U, 65U, 171U, 136U, 135U, 225U,
- 123U, 11U, 68U, 86U, 237U, 82U, 20U, 155U, 133U, 189U, 9U, 83U, 167U, 116U, 194U, 78U,
- 122U, 127U, 195U, 185U, 185U, 204U, 188U, 90U, 245U, 9U, 183U, 248U, 226U, 85U, 245U, 104U
- )
- val result = (0 until 1_000_000).fold(input) { acc, _ ->
- Salsa20Pure.hash(acc.fromLittleEndianToUInt())
- }
- result.contentEquals(expected)
- }
-
- }
-
- @Test
- fun testExpansion() {
- val k0 = ubyteArrayOf(1U, 2U, 3U, 4U, 5U, 6U, 7U, 8U, 9U, 10U, 11U, 12U, 13U, 14U, 15U, 16U)
- val k1 =
- ubyteArrayOf(201U, 202U, 203U, 204U, 205U, 206U, 207U, 208U, 209U, 210U, 211U, 212U, 213U, 214U, 215U, 216U)
- val n =
- ubyteArrayOf(101U, 102U, 103U, 104U, 105U, 106U, 107U, 108U, 109U, 110U, 111U, 112U, 113U, 114U, 115U, 116U)
-
- assertTrue {
- val expected = ubyteArrayOf(
- 69U, 37U, 68U, 39U, 41U, 15U, 107U, 193U, 255U, 139U, 122U, 6U, 170U, 233U, 217U, 98U,
- 89U, 144U, 182U, 106U, 21U, 51U, 200U, 65U, 239U, 49U, 222U, 34U, 215U, 114U, 40U, 126U,
- 104U, 197U, 7U, 225U, 197U, 153U, 31U, 2U, 102U, 78U, 76U, 176U, 84U, 245U, 246U, 184U,
- 177U, 160U, 133U, 130U, 6U, 72U, 149U, 119U, 192U, 195U, 132U, 236U, 234U, 103U, 246U, 74U
- )
- val result = Salsa20Pure.expansion32(k0 + k1, n)
- result.contentEquals(expected)
- }
-
- assertTrue {
- val expected = ubyteArrayOf(
- 39U, 173U, 46U, 248U, 30U, 200U, 82U, 17U, 48U, 67U, 254U, 239U, 37U, 18U, 13U, 247U,
- 241U, 200U, 61U, 144U, 10U, 55U, 50U, 185U, 6U, 47U, 246U, 253U, 143U, 86U, 187U, 225U,
- 134U, 85U, 110U, 246U, 161U, 163U, 43U, 235U, 231U, 94U, 171U, 51U, 145U, 214U, 112U, 29U,
- 14U, 232U, 5U, 16U, 151U, 140U, 183U, 141U, 171U, 9U, 122U, 181U, 104U, 182U, 177U, 193U
- )
- val result = Salsa20Pure.expansion16(k0, n)
- result.contentEquals(expected)
- }
- }
-
- @Test
- fun testSalsa20Encryption() {
- assertTrue {
- val key = "8000000000000000000000000000000000000000000000000000000000000000".hexStringToUByteArray()
- val nonce = "0000000000000000".hexStringToUByteArray()
- val expectedStartsWith = (
- "E3BE8FDD8BECA2E3EA8EF9475B29A6E7" +
- "003951E1097A5C38D23B7A5FAD9F6844" +
- "B22C97559E2723C7CBBD3FE4FC8D9A07" +
- "44652A83E72A9C461876AF4D7EF1A117").toLowerCase()
- val endsWith = (
- "696AFCFD0CDDCC83C7E77F11A649D79A" +
- "CDC3354E9635FF137E929933A0BD6F53" +
- "77EFA105A3A4266B7C0D089D08F1E855" +
- "CC32B15B93784A36E56A76CC64BC8477"
- ).toLowerCase()
-
- val ciphertext = Salsa20Pure.encrypt(key, nonce, UByteArray(512) { 0U })
- ciphertext.toHexString().toLowerCase().startsWith(expectedStartsWith) &&
- ciphertext.toHexString().toLowerCase().endsWith(endsWith)
- }
-
- assertTrue {
- val key = "0A5DB00356A9FC4FA2F5489BEE4194E73A8DE03386D92C7FD22578CB1E71C417".hexStringToUByteArray()
- val nonce = "1F86ED54BB2289F0".hexStringToUByteArray()
- val expectedStartsWith = (
- "3FE85D5BB1960A82480B5E6F4E965A44" +
- "60D7A54501664F7D60B54B06100A37FF" +
- "DCF6BDE5CE3F4886BA77DD5B44E95644" +
- "E40A8AC65801155DB90F02522B644023").toLowerCase()
- val endsWith = (
- "7998204FED70CE8E0D027B206635C08C" +
- "8BC443622608970E40E3AEDF3CE790AE" +
- "EDF89F922671B45378E2CD03F6F62356" +
- "529C4158B7FF41EE854B1235373988C8"
- ).toLowerCase()
-
- val ciphertext = Salsa20Pure.encrypt(key, nonce, UByteArray(131072) { 0U })
- println(ciphertext.slice(0 until 64).toTypedArray().toHexString())
- println(ciphertext.slice(131008 until 131072).toTypedArray().toHexString())
- ciphertext.slice(0 until 64).toTypedArray().toHexString().toLowerCase().startsWith(expectedStartsWith) &&
- ciphertext.slice(131008 until 131072).toTypedArray().toHexString().toLowerCase().contains(endsWith)
- }
-
-
- }
-
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/XChaCha20Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/XChaCha20Test.kt
deleted file mode 100644
index 53c9d2a..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/XChaCha20Test.kt
+++ /dev/null
@@ -1,341 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import com.ionspin.kotlin.crypto.util.hexColumsPrint
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 17-Jun-2020
- */
-class XChaCha20Test {
-
- @Test
- fun testHChaCha20() {
- val key = ubyteArrayOf(
- 0x00U, 0x01U, 0x02U, 0x03U, 0x04U, 0x05U, 0x06U, 0x07U, 0x08U, 0x09U,
- 0x0aU, 0x0bU, 0x0cU, 0x0dU, 0x0eU, 0x0fU, 0x10U, 0x11U, 0x12U, 0x13U,
- 0x14U, 0x15U, 0x16U, 0x17U, 0x18U, 0x19U, 0x1aU, 0x1bU, 0x1cU, 0x1dU,
- 0x1eU, 0x1fU
- )
-
- val nonce = ubyteArrayOf(
- 0x00U, 0x00U, 0x00U, 0x09U, 0x00U, 0x00U, 0x00U, 0x4aU,
- 0x00U, 0x00U, 0x00U, 0x00U, 0x31U, 0x41U, 0x59U, 0x27U
- )
-
- val expected = uintArrayOf(
- 0x82413b42U, 0x27b27bfeU, 0xd30e4250U, 0x8a877d73U,
- 0xa0f9e4d5U, 0x8a74a853U, 0xc12ec413U, 0x26d3ecdcU,
- )
-
- val result = XChaCha20Pure.hChacha(key, nonce)
-// assertTrue {
-// result.contentEquals(expected)//Returns little endia, expected big endian
-// }
- }
-
- @Test
- fun testXChaCha20() {
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU
- )
- val nonce = ubyteArrayOf(
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x58U
- )
- val message = ubyteArrayOf(
- 0x54U, 0x68U, 0x65U, 0x20U, 0x64U, 0x68U, 0x6fU, 0x6cU,
- 0x65U, 0x20U, 0x28U, 0x70U, 0x72U, 0x6fU, 0x6eU, 0x6fU,
- 0x75U, 0x6eU, 0x63U, 0x65U, 0x64U, 0x20U, 0x22U, 0x64U,
- 0x6fU, 0x6cU, 0x65U, 0x22U, 0x29U, 0x20U, 0x69U, 0x73U,
- 0x20U, 0x61U, 0x6cU, 0x73U, 0x6fU, 0x20U, 0x6bU, 0x6eU,
- 0x6fU, 0x77U, 0x6eU, 0x20U, 0x61U, 0x73U, 0x20U, 0x74U,
- 0x68U, 0x65U, 0x20U, 0x41U, 0x73U, 0x69U, 0x61U, 0x74U,
- 0x69U, 0x63U, 0x20U, 0x77U, 0x69U, 0x6cU, 0x64U, 0x20U,
- 0x64U, 0x6fU, 0x67U, 0x2cU, 0x20U, 0x72U, 0x65U, 0x64U,
- 0x20U, 0x64U, 0x6fU, 0x67U, 0x2cU, 0x20U, 0x61U, 0x6eU,
- 0x64U, 0x20U, 0x77U, 0x68U, 0x69U, 0x73U, 0x74U, 0x6cU,
- 0x69U, 0x6eU, 0x67U, 0x20U, 0x64U, 0x6fU, 0x67U, 0x2eU,
- 0x20U, 0x49U, 0x74U, 0x20U, 0x69U, 0x73U, 0x20U, 0x61U,
- 0x62U, 0x6fU, 0x75U, 0x74U, 0x20U, 0x74U, 0x68U, 0x65U,
- 0x20U, 0x73U, 0x69U, 0x7aU, 0x65U, 0x20U, 0x6fU, 0x66U,
- 0x20U, 0x61U, 0x20U, 0x47U, 0x65U, 0x72U, 0x6dU, 0x61U,
- 0x6eU, 0x20U, 0x73U, 0x68U, 0x65U, 0x70U, 0x68U, 0x65U,
- 0x72U, 0x64U, 0x20U, 0x62U, 0x75U, 0x74U, 0x20U, 0x6cU,
- 0x6fU, 0x6fU, 0x6bU, 0x73U, 0x20U, 0x6dU, 0x6fU, 0x72U,
- 0x65U, 0x20U, 0x6cU, 0x69U, 0x6bU, 0x65U, 0x20U, 0x61U,
- 0x20U, 0x6cU, 0x6fU, 0x6eU, 0x67U, 0x2dU, 0x6cU, 0x65U,
- 0x67U, 0x67U, 0x65U, 0x64U, 0x20U, 0x66U, 0x6fU, 0x78U,
- 0x2eU, 0x20U, 0x54U, 0x68U, 0x69U, 0x73U, 0x20U, 0x68U,
- 0x69U, 0x67U, 0x68U, 0x6cU, 0x79U, 0x20U, 0x65U, 0x6cU,
- 0x75U, 0x73U, 0x69U, 0x76U, 0x65U, 0x20U, 0x61U, 0x6eU,
- 0x64U, 0x20U, 0x73U, 0x6bU, 0x69U, 0x6cU, 0x6cU, 0x65U,
- 0x64U, 0x20U, 0x6aU, 0x75U, 0x6dU, 0x70U, 0x65U, 0x72U,
- 0x20U, 0x69U, 0x73U, 0x20U, 0x63U, 0x6cU, 0x61U, 0x73U,
- 0x73U, 0x69U, 0x66U, 0x69U, 0x65U, 0x64U, 0x20U, 0x77U,
- 0x69U, 0x74U, 0x68U, 0x20U, 0x77U, 0x6fU, 0x6cU, 0x76U,
- 0x65U, 0x73U, 0x2cU, 0x20U, 0x63U, 0x6fU, 0x79U, 0x6fU,
- 0x74U, 0x65U, 0x73U, 0x2cU, 0x20U, 0x6aU, 0x61U, 0x63U,
- 0x6bU, 0x61U, 0x6cU, 0x73U, 0x2cU, 0x20U, 0x61U, 0x6eU,
- 0x64U, 0x20U, 0x66U, 0x6fU, 0x78U, 0x65U, 0x73U, 0x20U,
- 0x69U, 0x6eU, 0x20U, 0x74U, 0x68U, 0x65U, 0x20U, 0x74U,
- 0x61U, 0x78U, 0x6fU, 0x6eU, 0x6fU, 0x6dU, 0x69U, 0x63U,
- 0x20U, 0x66U, 0x61U, 0x6dU, 0x69U, 0x6cU, 0x79U, 0x20U,
- 0x43U, 0x61U, 0x6eU, 0x69U, 0x64U, 0x61U, 0x65U, 0x2eU,
- )
-
- val expected = ubyteArrayOf(
- 0x7dU, 0x0aU, 0x2eU, 0x6bU, 0x7fU, 0x7cU, 0x65U, 0xa2U,
- 0x36U, 0x54U, 0x26U, 0x30U, 0x29U, 0x4eU, 0x06U, 0x3bU,
- 0x7aU, 0xb9U, 0xb5U, 0x55U, 0xa5U, 0xd5U, 0x14U, 0x9aU,
- 0xa2U, 0x1eU, 0x4aU, 0xe1U, 0xe4U, 0xfbU, 0xceU, 0x87U,
- 0xecU, 0xc8U, 0xe0U, 0x8aU, 0x8bU, 0x5eU, 0x35U, 0x0aU,
- 0xbeU, 0x62U, 0x2bU, 0x2fU, 0xfaU, 0x61U, 0x7bU, 0x20U,
- 0x2cU, 0xfaU, 0xd7U, 0x20U, 0x32U, 0xa3U, 0x03U, 0x7eU,
- 0x76U, 0xffU, 0xdcU, 0xdcU, 0x43U, 0x76U, 0xeeU, 0x05U,
- 0x3aU, 0x19U, 0x0dU, 0x7eU, 0x46U, 0xcaU, 0x1dU, 0xe0U,
- 0x41U, 0x44U, 0x85U, 0x03U, 0x81U, 0xb9U, 0xcbU, 0x29U,
- 0xf0U, 0x51U, 0x91U, 0x53U, 0x86U, 0xb8U, 0xa7U, 0x10U,
- 0xb8U, 0xacU, 0x4dU, 0x02U, 0x7bU, 0x8bU, 0x05U, 0x0fU,
- 0x7cU, 0xbaU, 0x58U, 0x54U, 0xe0U, 0x28U, 0xd5U, 0x64U,
- 0xe4U, 0x53U, 0xb8U, 0xa9U, 0x68U, 0x82U, 0x41U, 0x73U,
- 0xfcU, 0x16U, 0x48U, 0x8bU, 0x89U, 0x70U, 0xcaU, 0xc8U,
- 0x28U, 0xf1U, 0x1aU, 0xe5U, 0x3cU, 0xabU, 0xd2U, 0x01U,
- 0x12U, 0xf8U, 0x71U, 0x07U, 0xdfU, 0x24U, 0xeeU, 0x61U,
- 0x83U, 0xd2U, 0x27U, 0x4fU, 0xe4U, 0xc8U, 0xb1U, 0x48U,
- 0x55U, 0x34U, 0xefU, 0x2cU, 0x5fU, 0xbcU, 0x1eU, 0xc2U,
- 0x4bU, 0xfcU, 0x36U, 0x63U, 0xefU, 0xaaU, 0x08U, 0xbcU,
- 0x04U, 0x7dU, 0x29U, 0xd2U, 0x50U, 0x43U, 0x53U, 0x2dU,
- 0xb8U, 0x39U, 0x1aU, 0x8aU, 0x3dU, 0x77U, 0x6bU, 0xf4U,
- 0x37U, 0x2aU, 0x69U, 0x55U, 0x82U, 0x7cU, 0xcbU, 0x0cU,
- 0xddU, 0x4aU, 0xf4U, 0x03U, 0xa7U, 0xceU, 0x4cU, 0x63U,
- 0xd5U, 0x95U, 0xc7U, 0x5aU, 0x43U, 0xe0U, 0x45U, 0xf0U,
- 0xccU, 0xe1U, 0xf2U, 0x9cU, 0x8bU, 0x93U, 0xbdU, 0x65U,
- 0xafU, 0xc5U, 0x97U, 0x49U, 0x22U, 0xf2U, 0x14U, 0xa4U,
- 0x0bU, 0x7cU, 0x40U, 0x2cU, 0xdbU, 0x91U, 0xaeU, 0x73U,
- 0xc0U, 0xb6U, 0x36U, 0x15U, 0xcdU, 0xadU, 0x04U, 0x80U,
- 0x68U, 0x0fU, 0x16U, 0x51U, 0x5aU, 0x7aU, 0xceU, 0x9dU,
- 0x39U, 0x23U, 0x64U, 0x64U, 0x32U, 0x8aU, 0x37U, 0x74U,
- 0x3fU, 0xfcU, 0x28U, 0xf4U, 0xddU, 0xb3U, 0x24U, 0xf4U,
- 0xd0U, 0xf5U, 0xbbU, 0xdcU, 0x27U, 0x0cU, 0x65U, 0xb1U,
- 0x74U, 0x9aU, 0x6eU, 0xffU, 0xf1U, 0xfbU, 0xaaU, 0x09U,
- 0x53U, 0x61U, 0x75U, 0xccU, 0xd2U, 0x9fU, 0xb9U, 0xe6U,
- 0x05U, 0x7bU, 0x30U, 0x73U, 0x20U, 0xd3U, 0x16U, 0x83U,
- 0x8aU, 0x9cU, 0x71U, 0xf7U, 0x0bU, 0x5bU, 0x59U, 0x07U,
- 0xa6U, 0x6fU, 0x7eU, 0xa4U, 0x9aU, 0xadU, 0xc4U, 0x09U,
-
- )
-
- val result = XChaCha20Pure.xorWithKeystream(key, nonce, message, 1U)
- assertTrue {
- result.contentEquals(expected)
- }
-
- }
-
- @Test
- fun testXChaCha20Updateable() {
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU
- )
- val nonce = ubyteArrayOf(
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x58U
- )
- val message = ubyteArrayOf(
- 0x54U, 0x68U, 0x65U, 0x20U, 0x64U, 0x68U, 0x6fU, 0x6cU,
- 0x65U, 0x20U, 0x28U, 0x70U, 0x72U, 0x6fU, 0x6eU, 0x6fU,
- 0x75U, 0x6eU, 0x63U, 0x65U, 0x64U, 0x20U, 0x22U, 0x64U,
- 0x6fU, 0x6cU, 0x65U, 0x22U, 0x29U, 0x20U, 0x69U, 0x73U,
- 0x20U, 0x61U, 0x6cU, 0x73U, 0x6fU, 0x20U, 0x6bU, 0x6eU,
- 0x6fU, 0x77U, 0x6eU, 0x20U, 0x61U, 0x73U, 0x20U, 0x74U,
- 0x68U, 0x65U, 0x20U, 0x41U, 0x73U, 0x69U, 0x61U, 0x74U,
- 0x69U, 0x63U, 0x20U, 0x77U, 0x69U, 0x6cU, 0x64U, 0x20U,
- 0x64U, 0x6fU, 0x67U, 0x2cU, 0x20U, 0x72U, 0x65U, 0x64U,
- 0x20U, 0x64U, 0x6fU, 0x67U, 0x2cU, 0x20U, 0x61U, 0x6eU,
- 0x64U, 0x20U, 0x77U, 0x68U, 0x69U, 0x73U, 0x74U, 0x6cU,
- 0x69U, 0x6eU, 0x67U, 0x20U, 0x64U, 0x6fU, 0x67U, 0x2eU,
- 0x20U, 0x49U, 0x74U, 0x20U, 0x69U, 0x73U, 0x20U, 0x61U,
- 0x62U, 0x6fU, 0x75U, 0x74U, 0x20U, 0x74U, 0x68U, 0x65U,
- 0x20U, 0x73U, 0x69U, 0x7aU, 0x65U, 0x20U, 0x6fU, 0x66U,
- 0x20U, 0x61U, 0x20U, 0x47U, 0x65U, 0x72U, 0x6dU, 0x61U,
- 0x6eU, 0x20U, 0x73U, 0x68U, 0x65U, 0x70U, 0x68U, 0x65U,
- 0x72U, 0x64U, 0x20U, 0x62U, 0x75U, 0x74U, 0x20U, 0x6cU,
- 0x6fU, 0x6fU, 0x6bU, 0x73U, 0x20U, 0x6dU, 0x6fU, 0x72U,
- 0x65U, 0x20U, 0x6cU, 0x69U, 0x6bU, 0x65U, 0x20U, 0x61U,
- 0x20U, 0x6cU, 0x6fU, 0x6eU, 0x67U, 0x2dU, 0x6cU, 0x65U,
- 0x67U, 0x67U, 0x65U, 0x64U, 0x20U, 0x66U, 0x6fU, 0x78U,
- 0x2eU, 0x20U, 0x54U, 0x68U, 0x69U, 0x73U, 0x20U, 0x68U,
- 0x69U, 0x67U, 0x68U, 0x6cU, 0x79U, 0x20U, 0x65U, 0x6cU,
- 0x75U, 0x73U, 0x69U, 0x76U, 0x65U, 0x20U, 0x61U, 0x6eU,
- 0x64U, 0x20U, 0x73U, 0x6bU, 0x69U, 0x6cU, 0x6cU, 0x65U,
- 0x64U, 0x20U, 0x6aU, 0x75U, 0x6dU, 0x70U, 0x65U, 0x72U,
- 0x20U, 0x69U, 0x73U, 0x20U, 0x63U, 0x6cU, 0x61U, 0x73U,
- 0x73U, 0x69U, 0x66U, 0x69U, 0x65U, 0x64U, 0x20U, 0x77U,
- 0x69U, 0x74U, 0x68U, 0x20U, 0x77U, 0x6fU, 0x6cU, 0x76U,
- 0x65U, 0x73U, 0x2cU, 0x20U, 0x63U, 0x6fU, 0x79U, 0x6fU,
- 0x74U, 0x65U, 0x73U, 0x2cU, 0x20U, 0x6aU, 0x61U, 0x63U,
- 0x6bU, 0x61U, 0x6cU, 0x73U, 0x2cU, 0x20U, 0x61U, 0x6eU,
- 0x64U, 0x20U, 0x66U, 0x6fU, 0x78U, 0x65U, 0x73U, 0x20U,
- 0x69U, 0x6eU, 0x20U, 0x74U, 0x68U, 0x65U, 0x20U, 0x74U,
- 0x61U, 0x78U, 0x6fU, 0x6eU, 0x6fU, 0x6dU, 0x69U, 0x63U,
- 0x20U, 0x66U, 0x61U, 0x6dU, 0x69U, 0x6cU, 0x79U, 0x20U,
- 0x43U, 0x61U, 0x6eU, 0x69U, 0x64U, 0x61U, 0x65U, 0x2eU,
- )
-
- val expected = ubyteArrayOf(
- 0x7dU, 0x0aU, 0x2eU, 0x6bU, 0x7fU, 0x7cU, 0x65U, 0xa2U,
- 0x36U, 0x54U, 0x26U, 0x30U, 0x29U, 0x4eU, 0x06U, 0x3bU,
- 0x7aU, 0xb9U, 0xb5U, 0x55U, 0xa5U, 0xd5U, 0x14U, 0x9aU,
- 0xa2U, 0x1eU, 0x4aU, 0xe1U, 0xe4U, 0xfbU, 0xceU, 0x87U,
- 0xecU, 0xc8U, 0xe0U, 0x8aU, 0x8bU, 0x5eU, 0x35U, 0x0aU,
- 0xbeU, 0x62U, 0x2bU, 0x2fU, 0xfaU, 0x61U, 0x7bU, 0x20U,
- 0x2cU, 0xfaU, 0xd7U, 0x20U, 0x32U, 0xa3U, 0x03U, 0x7eU,
- 0x76U, 0xffU, 0xdcU, 0xdcU, 0x43U, 0x76U, 0xeeU, 0x05U,
- 0x3aU, 0x19U, 0x0dU, 0x7eU, 0x46U, 0xcaU, 0x1dU, 0xe0U,
- 0x41U, 0x44U, 0x85U, 0x03U, 0x81U, 0xb9U, 0xcbU, 0x29U,
- 0xf0U, 0x51U, 0x91U, 0x53U, 0x86U, 0xb8U, 0xa7U, 0x10U,
- 0xb8U, 0xacU, 0x4dU, 0x02U, 0x7bU, 0x8bU, 0x05U, 0x0fU,
- 0x7cU, 0xbaU, 0x58U, 0x54U, 0xe0U, 0x28U, 0xd5U, 0x64U,
- 0xe4U, 0x53U, 0xb8U, 0xa9U, 0x68U, 0x82U, 0x41U, 0x73U,
- 0xfcU, 0x16U, 0x48U, 0x8bU, 0x89U, 0x70U, 0xcaU, 0xc8U,
- 0x28U, 0xf1U, 0x1aU, 0xe5U, 0x3cU, 0xabU, 0xd2U, 0x01U,
- 0x12U, 0xf8U, 0x71U, 0x07U, 0xdfU, 0x24U, 0xeeU, 0x61U,
- 0x83U, 0xd2U, 0x27U, 0x4fU, 0xe4U, 0xc8U, 0xb1U, 0x48U,
- 0x55U, 0x34U, 0xefU, 0x2cU, 0x5fU, 0xbcU, 0x1eU, 0xc2U,
- 0x4bU, 0xfcU, 0x36U, 0x63U, 0xefU, 0xaaU, 0x08U, 0xbcU,
- 0x04U, 0x7dU, 0x29U, 0xd2U, 0x50U, 0x43U, 0x53U, 0x2dU,
- 0xb8U, 0x39U, 0x1aU, 0x8aU, 0x3dU, 0x77U, 0x6bU, 0xf4U,
- 0x37U, 0x2aU, 0x69U, 0x55U, 0x82U, 0x7cU, 0xcbU, 0x0cU,
- 0xddU, 0x4aU, 0xf4U, 0x03U, 0xa7U, 0xceU, 0x4cU, 0x63U,
- 0xd5U, 0x95U, 0xc7U, 0x5aU, 0x43U, 0xe0U, 0x45U, 0xf0U,
- 0xccU, 0xe1U, 0xf2U, 0x9cU, 0x8bU, 0x93U, 0xbdU, 0x65U,
- 0xafU, 0xc5U, 0x97U, 0x49U, 0x22U, 0xf2U, 0x14U, 0xa4U,
- 0x0bU, 0x7cU, 0x40U, 0x2cU, 0xdbU, 0x91U, 0xaeU, 0x73U,
- 0xc0U, 0xb6U, 0x36U, 0x15U, 0xcdU, 0xadU, 0x04U, 0x80U,
- 0x68U, 0x0fU, 0x16U, 0x51U, 0x5aU, 0x7aU, 0xceU, 0x9dU,
- 0x39U, 0x23U, 0x64U, 0x64U, 0x32U, 0x8aU, 0x37U, 0x74U,
- 0x3fU, 0xfcU, 0x28U, 0xf4U, 0xddU, 0xb3U, 0x24U, 0xf4U,
- 0xd0U, 0xf5U, 0xbbU, 0xdcU, 0x27U, 0x0cU, 0x65U, 0xb1U,
- 0x74U, 0x9aU, 0x6eU, 0xffU, 0xf1U, 0xfbU, 0xaaU, 0x09U,
- 0x53U, 0x61U, 0x75U, 0xccU, 0xd2U, 0x9fU, 0xb9U, 0xe6U,
- 0x05U, 0x7bU, 0x30U, 0x73U, 0x20U, 0xd3U, 0x16U, 0x83U,
- 0x8aU, 0x9cU, 0x71U, 0xf7U, 0x0bU, 0x5bU, 0x59U, 0x07U,
- 0xa6U, 0x6fU, 0x7eU, 0xa4U, 0x9aU, 0xadU, 0xc4U, 0x09U,
-
- )
-
- val xChaCha = XChaCha20Pure(key, nonce, 1U)
- val firstChunk = xChaCha.xorWithKeystream(message.sliceArray(0 until 5))
- val secondChunk = xChaCha.xorWithKeystream(message.sliceArray(5 until 90))
- val thirdChunk = xChaCha.xorWithKeystream(message.sliceArray(90 until message.size))
- val result = firstChunk + secondChunk + thirdChunk
- assertTrue {
- (result).contentEquals(expected)
- }
-
- }
-
- @Test
- fun testXChaCha20UpdateableLonger() {
- val key = ubyteArrayOf(
- 0x80U, 0x81U, 0x82U, 0x83U, 0x84U, 0x85U, 0x86U, 0x87U,
- 0x88U, 0x89U, 0x8aU, 0x8bU, 0x8cU, 0x8dU, 0x8eU, 0x8fU,
- 0x90U, 0x91U, 0x92U, 0x93U, 0x94U, 0x95U, 0x96U, 0x97U,
- 0x98U, 0x99U, 0x9aU, 0x9bU, 0x9cU, 0x9dU, 0x9eU, 0x9fU
- )
- val nonce = ubyteArrayOf(
- 0x40U, 0x41U, 0x42U, 0x43U, 0x44U, 0x45U, 0x46U, 0x47U,
- 0x48U, 0x49U, 0x4aU, 0x4bU, 0x4cU, 0x4dU, 0x4eU, 0x4fU,
- 0x50U, 0x51U, 0x52U, 0x53U, 0x54U, 0x55U, 0x56U, 0x58U
- )
- val message = ("This is a longer message that should cover all cases in the updateable algorithm. This string is 112 bytes long." +
- "This is a longer message that should cover all cases in the updateable algorithm. This string is 112 bytes long." +
- "This is a longer message that should cover all cases in the updateable algorithm. This string is 112 bytes long." +
- "This is a longer message that should cover all cases in the updateable algorithm. This string is 112 bytes long.").encodeToUByteArray()
-
- val expected = ubyteArrayOf(
- 0x7DU, 0x0AU, 0x22U, 0x38U, 0x3BU, 0x7DU, 0x79U, 0xEEU,
- 0x32U, 0x54U, 0x62U, 0x2FU, 0x35U, 0x46U, 0x0DU, 0x26U,
- 0x2FU, 0xBAU, 0xB3U, 0x43U, 0xB2U, 0x94U, 0x51U, 0x9BU,
- 0xEDU, 0x06U, 0x47U, 0xA2U, 0xB9U, 0xFBU, 0xD4U, 0x9CU,
- 0xA3U, 0xDCU, 0xE0U, 0x9DU, 0xC4U, 0x1DU, 0x31U, 0x12U,
- 0xB4U, 0x67U, 0x65U, 0x6EU, 0xF7U, 0x7EU, 0x7BU, 0x37U,
- 0x25U, 0xECU, 0x92U, 0x12U, 0x61U, 0xA3U, 0x0CU, 0x2AU,
- 0x6BU, 0xF4U, 0x99U, 0x8BU, 0x5FU, 0x6AU, 0xEEU, 0x44U,
- 0x2AU, 0x13U, 0x0BU, 0x30U, 0x0AU, 0xDDU, 0x58U, 0xE5U,
- 0x0DU, 0x47U, 0x85U, 0x16U, 0xC4U, 0xEDU, 0xC2U, 0x2AU,
- 0xBAU, 0x51U, 0xB2U, 0x53U, 0x86U, 0xB8U, 0xF3U, 0x0FU,
- 0xA5U, 0xB0U, 0x43U, 0x4CU, 0x78U, 0xC4U, 0x0BU, 0x52U,
- 0x7CU, 0xC2U, 0x1DU, 0x46U, 0xA9U, 0x39U, 0x8CU, 0x71U,
- 0xE3U, 0x4FU, 0xEDU, 0xB1U, 0x27U, 0x98U, 0x4EU, 0x38U,
- 0x88U, 0x0DU, 0x48U, 0x82U, 0xCCU, 0x39U, 0xD6U, 0x8EU,
- 0x69U, 0xB0U, 0x56U, 0xCDU, 0x37U, 0xBEU, 0xDAU, 0x12U,
- 0x5CU, 0xB5U, 0x67U, 0x1CU, 0xC9U, 0x35U, 0xE1U, 0x61U,
- 0xD1U, 0xC2U, 0x6FU, 0x4CU, 0xE5U, 0x9CU, 0xE2U, 0x4CU,
- 0x55U, 0x2EU, 0xE8U, 0x3BU, 0x5FU, 0xB2U, 0x1EU, 0xC6U,
- 0x4BU, 0xAEU, 0x7AU, 0x6BU, 0xE8U, 0xA3U, 0x08U, 0xBEU,
- 0x45U, 0x62U, 0x23U, 0xCFU, 0x17U, 0x07U, 0x51U, 0x68U,
- 0xABU, 0x36U, 0x1AU, 0xCEU, 0x68U, 0x61U, 0x60U, 0xEDU,
- 0x6DU, 0x6FU, 0x5CU, 0x5FU, 0x87U, 0x6AU, 0xCBU, 0x05U,
- 0xD8U, 0x4AU, 0xF3U, 0x1DU, 0xB7U, 0x9AU, 0x41U, 0x62U,
- 0x8EU, 0xC6U, 0xFAU, 0x44U, 0x4FU, 0xB3U, 0x04U, 0xEDU,
- 0xDCU, 0xB3U, 0xE8U, 0x99U, 0x85U, 0xDFU, 0xB8U, 0x73U,
- 0xEBU, 0xD4U, 0xCCU, 0x0EU, 0x6FU, 0xE0U, 0x08U, 0xA2U,
- 0x4EU, 0x66U, 0x13U, 0x60U, 0xD7U, 0x93U, 0xA8U, 0x2EU,
- 0xE7U, 0xB7U, 0x39U, 0x0FU, 0x88U, 0xA0U, 0x57U, 0xD7U,
- 0x60U, 0x5BU, 0x12U, 0x1EU, 0x43U, 0x72U, 0xC7U, 0x99U,
- 0x7CU, 0x3DU, 0x2DU, 0x37U, 0x22U, 0x84U, 0x29U, 0x7EU,
- 0x6BU, 0xEDU, 0x33U, 0xB9U, 0x89U, 0xF9U, 0x36U, 0xFFU,
- 0xD4U, 0xE1U, 0xBBU, 0xCBU, 0x2BU, 0x4FU, 0x6BU, 0xA9U,
- 0x75U, 0xC8U, 0x28U, 0xF1U, 0xE5U, 0xF2U, 0xF9U, 0x4AU,
- 0x5BU, 0x7CU, 0x30U, 0xCBU, 0x9AU, 0x93U, 0xF7U, 0xB2U,
- 0x10U, 0x6BU, 0x3AU, 0x3DU, 0x3AU, 0xCEU, 0x1BU, 0x81U,
- 0xDEU, 0x9FU, 0x71U, 0xF8U, 0x0EU, 0x52U, 0x00U, 0x46U,
- 0x89U, 0x69U, 0x7FU, 0xBFU, 0x97U, 0xB8U, 0xC9U, 0x4AU,
- 0x3AU, 0x37U, 0x31U, 0x1EU, 0x88U, 0x68U, 0x35U, 0x98U,
- 0x76U, 0x93U, 0xCDU, 0x91U, 0xF7U, 0x6AU, 0x59U, 0xE6U,
- 0x82U, 0xB6U, 0x85U, 0x67U, 0x3FU, 0xF5U, 0x9EU, 0x82U,
- 0x2DU, 0xFFU, 0x81U, 0x5EU, 0xEAU, 0x3BU, 0xCCU, 0xFBU,
- 0x1BU, 0x87U, 0x4AU, 0x93U, 0x40U, 0x96U, 0x3CU, 0xB2U,
- 0x8EU, 0xCCU, 0x38U, 0x00U, 0x3FU, 0xBAU, 0xCCU, 0x84U,
- 0x88U, 0x2BU, 0xF0U, 0x11U, 0x09U, 0xD5U, 0xAAU, 0x54U,
- 0x3AU, 0x5BU, 0x98U, 0xE6U, 0xADU, 0xC0U, 0xB9U, 0x95U,
- 0x53U, 0xDFU, 0x9DU, 0x91U, 0x01U, 0x66U, 0x7CU, 0xB3U,
- 0xD8U, 0x2BU, 0x2DU, 0xBCU, 0xE0U, 0x77U, 0x71U, 0x59U,
- 0x36U, 0xACU, 0x6DU, 0x5EU, 0x55U, 0xC9U, 0x29U, 0x40U,
- 0xD4U, 0xA2U, 0x5BU, 0xBDU, 0xC2U, 0xE2U, 0x98U, 0x3DU,
- 0x8CU, 0x9FU, 0x07U, 0xE4U, 0x21U, 0x84U, 0x4CU, 0x12U,
- 0x83U, 0x77U, 0x88U, 0x06U, 0xA4U, 0x6FU, 0xDFU, 0x9EU,
- 0xF5U, 0xD3U, 0xE1U, 0xFCU, 0x49U, 0x66U, 0x36U, 0x96U,
- 0x48U, 0xC7U, 0x32U, 0xBAU, 0x73U, 0xFFU, 0xEFU, 0xCCU,
- 0x00U, 0xC2U, 0x56U, 0x9CU, 0xD0U, 0x70U, 0x2AU, 0x4FU,
- 0x82U, 0xB4U, 0x0BU, 0x68U, 0xEAU, 0xC1U, 0x87U, 0xB3U,
-
- )
-
- val xChaCha = XChaCha20Pure(key, nonce, 1U)
- val firstChunk = xChaCha.xorWithKeystream(message.sliceArray(0 until 50))
- val secondChunk = xChaCha.xorWithKeystream(message.sliceArray(50 until 200))
- val thirdChunk = xChaCha.xorWithKeystream(message.sliceArray(200 until message.size))
- val result = (firstChunk + secondChunk + thirdChunk)
- assertTrue {
- result.contentEquals(expected)
- }
-
-
-
- }
-
-}
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/XSalsa20Test.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/XSalsa20Test.kt
deleted file mode 100644
index 4f74b04..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/symmetric/XSalsa20Test.kt
+++ /dev/null
@@ -1,44 +0,0 @@
-package com.ionspin.kotlin.crypto.symmetric
-
-import com.ionspin.kotlin.crypto.hash.encodeToUByteArray
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 16-Jun-2020
- */
-class XSalsa20Test {
- @Test
- fun testXSalsa20() {
- // values from https://go.googlesource.com/crypto/+/master/salsa20/salsa20_test.go xSalsa20TestData
- assertTrue {
- val message = "Hello world!".encodeToUByteArray()
- val nonce = "24-byte nonce for xsalsa".encodeToUByteArray()
- val key = "this is 32-byte key for xsalsa20".encodeToUByteArray()
- val expected = ubyteArrayOf(0x00U, 0x2dU, 0x45U, 0x13U, 0x84U, 0x3fU, 0xc2U, 0x40U, 0xc4U, 0x01U, 0xe5U, 0x41U)
- val result = XSalsa20Pure.encrypt(key, nonce, message)
- result.contentEquals(expected)
- }
-
- assertTrue {
- val message = UByteArray(64) { 0U }
- val nonce = "24-byte nonce for xsalsa".encodeToUByteArray()
- val key = "this is 32-byte key for xsalsa20".encodeToUByteArray()
- val expected = ubyteArrayOf(
- 0x48U, 0x48U, 0x29U, 0x7fU, 0xebU, 0x1fU, 0xb5U, 0x2fU, 0xb6U,
- 0x6dU, 0x81U, 0x60U, 0x9bU, 0xd5U, 0x47U, 0xfaU, 0xbcU, 0xbeU, 0x70U,
- 0x26U, 0xedU, 0xc8U, 0xb5U, 0xe5U, 0xe4U, 0x49U, 0xd0U, 0x88U, 0xbfU,
- 0xa6U, 0x9cU, 0x08U, 0x8fU, 0x5dU, 0x8dU, 0xa1U, 0xd7U, 0x91U, 0x26U,
- 0x7cU, 0x2cU, 0x19U, 0x5aU, 0x7fU, 0x8cU, 0xaeU, 0x9cU, 0x4bU, 0x40U,
- 0x50U, 0xd0U, 0x8cU, 0xe6U, 0xd3U, 0xa1U, 0x51U, 0xecU, 0x26U, 0x5fU,
- 0x3aU, 0x58U, 0xe4U, 0x76U, 0x48U
- )
- val result = XSalsa20Pure.encrypt(key, nonce, message)
- result.contentEquals(expected)
- }
-
-
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/util/TestUtil.kt b/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/util/TestUtil.kt
deleted file mode 100644
index 3cb5304..0000000
--- a/multiplatform-crypto/src/commonTest/kotlin/com/ionspin/kotlin/crypto/util/TestUtil.kt
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto.util
-
-import kotlin.coroutines.Continuation
-import kotlin.coroutines.EmptyCoroutineContext
-import kotlin.coroutines.startCoroutine
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 20-Jul-2019
- */
-fun testBlocking(block : suspend () -> Unit) {
- val continuation = Continuation(EmptyCoroutineContext) {
- //Do nothing
- if (it.isFailure) {
- throw it.exceptionOrNull()!!
- }
- }
- block.startCoroutine(continuation)
-}
diff --git a/multiplatform-crypto/src/iosMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto/src/iosMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto/src/iosTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto/src/iosTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto/src/jsMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto/src/jsMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index d9ddbd0..0000000
--- a/multiplatform-crypto/src/jsMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import kotlin.browser.window
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-actual object SRNG {
- var counter = 0
-
- actual fun getRandomBytes(amount: Int): UByteArray {
- val runningOnNode = jsTypeOf(window) == "undefined"
- val randomBytes = if (runningOnNode) {
- println("Running on node")
- js("require('crypto')").randomBytes(amount).toJSON().data
- } else {
- println("Running in browser")
- js(
- """
- var randomArray = new Uint8Array(amount);
- var crypto = (self.crypto || self.msCrypto);
- crypto.getRandomValues(randomArray);
- """
- )
- var randomArrayResult = js("Array.prototype.slice.call(randomArray);")
- randomArrayResult
- }
- println("Random bytes: $randomBytes")
- print("Byte at ${randomBytes[0]}")
- val randomBytesUByteArray = UByteArray(amount) {
- 0U
- }
- for (i in 0 until amount) {
- js("""
- randomBytesUByteArray[i] = randomBytes[i]
- """)
- }
- return randomBytesUByteArray
- }
-
-
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/jsTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto/src/jsTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto/src/jsTest/kotlin/com/ionspin/kotlin/crypto/SRNGJsTest.kt b/multiplatform-crypto/src/jsTest/kotlin/com/ionspin/kotlin/crypto/SRNGJsTest.kt
deleted file mode 100644
index 594e59f..0000000
--- a/multiplatform-crypto/src/jsTest/kotlin/com/ionspin/kotlin/crypto/SRNGJsTest.kt
+++ /dev/null
@@ -1,49 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import kotlin.test.Test
-import kotlin.test.assertTrue
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 05-Jan-2020
- */
-
-class SRNGJsTest {
-
- @Test
- fun testJsSrng() {
- val bytes1 = SRNG.getRandomBytes(10)
- val bytes2 = SRNG.getRandomBytes(10)
- println("BYTES1")
- bytes1.forEach {
- print(it.toString(16).padStart(2, '0'))
- }
- println("BYTES2")
- bytes2.forEach {
- print(it.toString(16).padStart(2, '0'))
- }
- assertTrue {
- !bytes1.contentEquals(bytes2) &&
- bytes1.size == 10 &&
- bytes2.size == 10
- }
-
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/jvmMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto/src/jvmMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index 3d50e6f..0000000
--- a/multiplatform-crypto/src/jvmMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import java.security.SecureRandom
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-
-actual object SRNG {
- val secureRandom = SecureRandom()
- actual fun getRandomBytes(amount: Int): UByteArray {
- val byteArray = ByteArray(amount)
- secureRandom.nextBytes(byteArray)
- return byteArray.asUByteArray()
- }
-}
diff --git a/multiplatform-crypto/src/linuxMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto/src/linuxMain/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto/src/linuxTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto/src/linuxTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/multiplatform-crypto/src/mingwX64Main/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto/src/mingwX64Main/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index c9172fd..0000000
--- a/multiplatform-crypto/src/mingwX64Main/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import kotlinx.cinterop.*
-import platform.windows.*
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-actual object SRNG {
- private val advapi by lazy { LoadLibraryA("ADVAPI32.DLL")}
-
- private val advapiRandom by lazy {
- GetProcAddress(advapi, "SystemFunction036")?.reinterpret, ULong, Int>>>() ?: error("Failed getting advapi random")
- }
-
- @Suppress("EXPERIMENTAL_UNSIGNED_LITERALS")
- actual fun getRandomBytes(amount: Int): UByteArray {
- memScoped {
- val randArray = allocArray(amount)
- val pointer = randArray.getPointer(this)
- val status = advapiRandom(pointer.reinterpret(), amount.convert())
- return UByteArray(amount) { pointer[it].toUByte() }
- }
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt b/multiplatform-crypto/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
deleted file mode 100644
index e76cf80..0000000
--- a/multiplatform-crypto/src/nativeMain/kotlin/com/ionspin/kotlin/crypto/SRNG.kt
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * Copyright 2019 Ugljesa Jovanovic
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.ionspin.kotlin.crypto
-
-import kotlinx.cinterop.*
-import platform.posix.*
-
-/**
- * Created by Ugljesa Jovanovic
- * ugljesa.jovanovic@ionspin.com
- * on 21-Sep-2019
- */
-actual object SRNG {
- @Suppress("EXPERIMENTAL_UNSIGNED_LITERALS")
- actual fun getRandomBytes(amount: Int): UByteArray {
- memScoped {
- val array = allocArray(amount)
- val urandomFile = fopen("/dev/urandom", "rb")
- if (urandomFile != null) {
- fread(array, 1, amount.convert(), urandomFile)
- }
- return UByteArray(amount) {
- array[it]
- }
- }
- }
-}
\ No newline at end of file
diff --git a/multiplatform-crypto/src/nativeTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder b/multiplatform-crypto/src/nativeTest/kotlin/com/ionspin/kotlin/bignum/integer/Placeholder
deleted file mode 100644
index e69de29..0000000
diff --git a/sample/build.gradle.kts b/sample/build.gradle.kts
index c03b151..295d20b 100644
--- a/sample/build.gradle.kts
+++ b/sample/build.gradle.kts
@@ -19,6 +19,7 @@
import org.jetbrains.kotlin.gradle.targets.js.testing.KotlinJsTest
import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest
+import org.gradle.api.tasks.testing.logging.TestExceptionFormat
import org.jetbrains.kotlin.gradle.tasks.FatFrameworkTask
plugins {
@@ -68,21 +69,20 @@ kotlin {
}
testTask {
- enabled = false //Until I sort out testing on travis
useKarma {
useChrome()
}
}
}
nodejs {
-
testTask {
useMocha() {
timeout = "10s"
}
}
}
- binaries.executable()
+
+// binaries.executable()
}
@@ -476,7 +476,9 @@ tasks {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
- // showStandardStreams = true
+ exceptionFormat = TestExceptionFormat.FULL
+ showStandardStreams = true
+ showStackTraces = true
}
}
diff --git a/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/DataPackage.kt b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/DataPackage.kt
new file mode 100644
index 0000000..9dca8ac
--- /dev/null
+++ b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/DataPackage.kt
@@ -0,0 +1,36 @@
+package com.ionspin.kotlin.crypto.sample
+
+import com.ionspin.kotlin.crypto.util.encodeToUByteArray
+import com.ionspin.kotlin.crypto.util.hexStringToUByteArray
+
+/**
+ * Created by Ugljesa Jovanovic
+ * ugljesa.jovanovic@ionspin.com
+ * on 30-Oct-2020
+ */
+interface DataPackage {
+ fun getContentAsUByteArray() : UByteArray
+ fun getStringRepresentation() : String
+}
+
+data class Utf8StringData(val content: String) : DataPackage {
+ override fun getContentAsUByteArray(): UByteArray {
+ return content.encodeToUByteArray()
+ }
+
+ override fun getStringRepresentation(): String {
+ return content
+ }
+}
+
+data class HexadecimalStringData(val content: String) : DataPackage {
+ override fun getContentAsUByteArray(): UByteArray {
+ return content.hexStringToUByteArray()
+ }
+
+ override fun getStringRepresentation(): String {
+ return content
+ }
+}
+
+//data class FileData(val filePath: )
diff --git a/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/FileWrapper.kt b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/FileWrapper.kt
new file mode 100644
index 0000000..8e874a2
--- /dev/null
+++ b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/FileWrapper.kt
@@ -0,0 +1,11 @@
+package com.ionspin.kotlin.crypto.sample
+
+/**
+ * Created by Ugljesa Jovanovic
+ * ugljesa.jovanovic@ionspin.com
+ * on 30-Oct-2020
+ */
+//expect class FileWrapper(path: String) {
+// fun exists() : Boolean
+//// fun rea
+//}
diff --git a/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/ui/LandingController.kt b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/ui/LandingController.kt
index 3166bc3..730bfb7 100644
--- a/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/ui/LandingController.kt
+++ b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/ui/LandingController.kt
@@ -7,4 +7,5 @@ package com.ionspin.kotlin.crypto.sample.ui
*/
class LandingController {
+
}
diff --git a/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchController.kt b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchController.kt
new file mode 100644
index 0000000..3fb409d
--- /dev/null
+++ b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchController.kt
@@ -0,0 +1,7 @@
+package com.ionspin.kotlin.crypto.sample.workbench
+
+/**
+ * Created by Ugljesa Jovanovic
+ * ugljesa.jovanovic@ionspin.com
+ * on 30-Oct-2020
+ */
diff --git a/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchElement.kt b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchElement.kt
new file mode 100644
index 0000000..95f831f
--- /dev/null
+++ b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchElement.kt
@@ -0,0 +1,10 @@
+package com.ionspin.kotlin.crypto.sample.workbench
+
+/**
+ * Created by Ugljesa Jovanovic
+ * ugljesa.jovanovic@ionspin.com
+ * on 30-Oct-2020
+ */
+interface WorkbenchElement {
+
+}
diff --git a/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchView.kt b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchView.kt
new file mode 100644
index 0000000..59ad00f
--- /dev/null
+++ b/sample/src/commonMain/kotlin/com/ionspin/kotlin/crypto/sample/workbench/WorkbenchView.kt
@@ -0,0 +1,10 @@
+package com.ionspin.kotlin.crypto.sample.workbench
+
+/**
+ * Created by Ugljesa Jovanovic
+ * ugljesa.jovanovic@ionspin.com
+ * on 30-Oct-2020
+ */
+interface WorkbenchView {
+
+}
diff --git a/settings.gradle.kts b/settings.gradle.kts
index 085d14b..884beca 100644
--- a/settings.gradle.kts
+++ b/settings.gradle.kts
@@ -36,8 +36,6 @@ pluginManagement {
enableFeaturePreview("GRADLE_METADATA")
rootProject.name = "KotlinMultiplatformCrypto"
include("multiplatform-crypto-api")
-include("multiplatform-crypto")
-include("multiplatform-crypto-delegated")
include("multiplatform-crypto-libsodium-bindings")
include("sample")
diff --git a/windowsBuild-delegated.sh b/windowsBuild-delegated.sh
index 67662a6..3a2bcbe 100755
--- a/windowsBuild-delegated.sh
+++ b/windowsBuild-delegated.sh
@@ -12,7 +12,6 @@ make -j4 -C libsodium install
echo "completed libsodium build"
#now we can do the delegated build
cd ..
-./gradlew --no-daemon multiplatform-crypto-delegated:build || exit 1
#and then libsodium bindings
./gradlew --no-daemon multiplatform-crypto-libsodium-bindings:build || exit 1
exit 0
diff --git a/windowsBuild-pure.sh b/windowsBuild-pure.sh
deleted file mode 100755
index 9286a7d..0000000
--- a/windowsBuild-pure.sh
+++ /dev/null
@@ -1,6 +0,0 @@
-#!/bin/sh
-./gradlew --no-daemon multiplatform-crypto-api:build || exit 1
-./gradlew --no-daemon multiplatform-crypto:build || exit 1
-exit 0
-
-
diff --git a/windowsBuildAndPublish-delegated.sh b/windowsBuildAndPublish-delegated.sh
index 2215ea9..9281e98 100755
--- a/windowsBuildAndPublish-delegated.sh
+++ b/windowsBuildAndPublish-delegated.sh
@@ -12,9 +12,6 @@ make -j4 -C libsodium install
echo "completed libsodium build"
#now we can do the delegated build
cd ..
-./gradlew --no-daemon multiplatform-crypto-delegated:build || exit 1
-./gradlew --no-daemon multiplatform-crypto-delegated:publishMingwX64PublicationToSnapshotRepository || exit 1
-
./gradlew --no-daemon multiplatform-crypto-libsodium-bindings:build || exit 1
./gradlew --no-daemon multiplatform-crypto-libsodium-bindings:publishMingwX64PublicationToSnapshotRepository || exit 1
exit 0
diff --git a/windowsBuildAndPublish-pure.sh b/windowsBuildAndPublish-pure.sh
deleted file mode 100755
index 9f5bf76..0000000
--- a/windowsBuildAndPublish-pure.sh
+++ /dev/null
@@ -1,7 +0,0 @@
-#!/bin/sh
-#this will hopefully download all konan dependancies that we use in the build scripts
-./gradlew clean || exit 1
-./gradlew --no-daemon multiplatform-crypto-api:build || exit 1
-./gradlew --no-daemon multiplatform-crypto:build || exit 1
-./gradlew --no-daemon multiplatform-crypto:publishMingwX64PublicationToSnapshotRepository || exit 1
-exit 0