Skip to content

Commit f6caff0

Browse files
committed
Update
1 parent 08cefb4 commit f6caff0

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

52 files changed

+309
-182
lines changed

.idea/gradle.xml

+1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/vcs.xml

+6
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

PQCLibrary/.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
/build

PQCLibrary/build.gradle

+35
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
plugins {
2+
id 'com.android.library'
3+
}
4+
5+
android {
6+
compileSdk 32
7+
8+
defaultConfig {
9+
minSdk 21
10+
targetSdk 32
11+
12+
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
13+
consumerProguardFiles "consumer-rules.pro"
14+
}
15+
16+
buildTypes {
17+
release {
18+
minifyEnabled false
19+
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
20+
}
21+
}
22+
compileOptions {
23+
sourceCompatibility JavaVersion.VERSION_1_8
24+
targetCompatibility JavaVersion.VERSION_1_8
25+
}
26+
}
27+
28+
dependencies {
29+
implementation 'com.github.aelstad:keccakj:1.1.0'
30+
implementation 'androidx.appcompat:appcompat:1.5.1'
31+
implementation 'com.google.android.material:material:1.7.0'
32+
testImplementation 'junit:junit:4.13.2'
33+
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
34+
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
35+
}

PQCLibrary/consumer-rules.pro

Whitespace-only changes.

PQCLibrary/proguard-rules.pro

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
# Add project specific ProGuard rules here.
2+
# You can control the set of applied configuration files using the
3+
# proguardFiles setting in build.gradle.
4+
#
5+
# For more details, see
6+
# http://developer.android.com/guide/developing/tools/proguard.html
7+
8+
# If your project uses WebView with JS, uncomment the following
9+
# and specify the fully qualified class name to the JavaScript interface
10+
# class:
11+
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
12+
# public *;
13+
#}
14+
15+
# Uncomment this to preserve the line number information for
16+
# debugging stack traces.
17+
#-keepattributes SourceFile,LineNumberTable
18+
19+
# If you keep the line number information, uncomment this to
20+
# hide the original source file name.
21+
#-renamesourcefileattribute SourceFile
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
package com.sak.pqclibrary;
2+
3+
import android.content.Context;
4+
5+
import androidx.test.platform.app.InstrumentationRegistry;
6+
import androidx.test.ext.junit.runners.AndroidJUnit4;
7+
8+
import org.junit.Test;
9+
import org.junit.runner.RunWith;
10+
11+
import static org.junit.Assert.*;
12+
13+
/**
14+
* Instrumented test, which will execute on an Android device.
15+
*
16+
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
17+
*/
18+
@RunWith(AndroidJUnit4.class)
19+
public class ExampleInstrumentedTest {
20+
@Test
21+
public void useAppContext() {
22+
// Context of the app under test.
23+
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
24+
assertEquals("com.sak.pqclibrary.test", appContext.getPackageName());
25+
}
26+
}
+5
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
3+
package="com.sak.pqclibrary">
4+
5+
</manifest>

app/src/main/java/com/sak/pqclibary/PQCLibary.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/PQCLibary.java

+42-18
Original file line numberDiff line numberDiff line change
@@ -1,20 +1,20 @@
1-
package com.sak.pqclibary;
1+
package com.sak.pqclibrary;
22

33
import android.os.Build;
44

55
import androidx.annotation.RequiresApi;
66

7-
import com.sak.pqclibary.kyber.kyberencryption.provider.Kyber1024KeyPairGenerator;
8-
import com.sak.pqclibary.kyber.kyberencryption.provider.Kyber512KeyPairGenerator;
9-
import com.sak.pqclibary.kyber.kyberencryption.provider.Kyber768KeyPairGenerator;
10-
import com.sak.pqclibary.kyber.kyberencryption.provider.KyberKeyPair;
11-
import com.sak.pqclibary.kyber.kyberencryption.provider.KyberProcess;
12-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.KyberParams;
13-
import com.sak.pqclibary.ntru.OWCPA;
14-
import com.sak.pqclibary.saber.Kem;
15-
import com.sak.pqclibary.saber.Params;
16-
import com.sak.pqclibary.saber.models.EncapsulationModel;
17-
import com.sak.pqclibary.saber.models.Keys;
7+
import com.sak.pqclibrary.kyber.kyberencryption.provider.Kyber1024KeyPair;
8+
import com.sak.pqclibrary.kyber.kyberencryption.provider.Kyber512KeyPair;
9+
import com.sak.pqclibrary.kyber.kyberencryption.provider.Kyber768KeyPair;
10+
import com.sak.pqclibrary.kyber.kyberencryption.provider.KyberKeyPair;
11+
import com.sak.pqclibrary.kyber.kyberencryption.provider.KyberProcess;
12+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.KyberParams;
13+
import com.sak.pqclibrary.ntru.OWCPA;
14+
import com.sak.pqclibrary.saber.Kem;
15+
import com.sak.pqclibrary.saber.Params;
16+
import com.sak.pqclibrary.saber.models.EncapsulationModel;
17+
import com.sak.pqclibrary.saber.models.Keys;
1818

1919
public class PQCLibary {
2020
byte[] pk;
@@ -48,14 +48,14 @@ else if(a[1].equalsIgnoreCase("Fire")){
4848
else if(a[0].equalsIgnoreCase("NTRU")){
4949
if(a[1].equalsIgnoreCase("509")){
5050

51-
new com.sak.pqclibary.ntru.Params(509);
51+
new com.sak.pqclibrary.ntru.Params(509);
5252

5353
}
5454
else if(a[1].equalsIgnoreCase("677")){
55-
new com.sak.pqclibary.ntru.Params(677);
55+
new com.sak.pqclibrary.ntru.Params(677);
5656
}
5757
else if(a[1].equalsIgnoreCase("821")){
58-
new com.sak.pqclibary.ntru.Params(821);
58+
new com.sak.pqclibrary.ntru.Params(821);
5959
}
6060
this.algorithmType = 2;
6161
keys = OWCPA.owcpa_keypair();
@@ -65,15 +65,15 @@ else if(a[0].equalsIgnoreCase("Kyber")){
6565
KyberKeyPair kk =null;
6666

6767
if(a[1].equalsIgnoreCase("512")){
68-
kk = Kyber512KeyPairGenerator.generateKeys512();
68+
kk = Kyber512KeyPair.generateKeys512();
6969
this.algorithmType = 3;
7070
}
7171
else if(a[1].equalsIgnoreCase("768")){
72-
kk = Kyber768KeyPairGenerator.generateKeys768();
72+
kk = Kyber768KeyPair.generateKeys768();
7373
this.algorithmType = 4;
7474
}
7575
else if(a[1].equalsIgnoreCase("1024")){
76-
kk = Kyber1024KeyPairGenerator.generateKeys1024();
76+
kk = Kyber1024KeyPair.generateKeys1024();
7777
this.algorithmType = 5;
7878
}
7979
keys = new Keys(kk.getKyberPublicKey(),kk.getKyberPrivateKey());
@@ -83,6 +83,30 @@ else if(a[1].equalsIgnoreCase("1024")){
8383
this.sk = keys.getSk();
8484
}
8585

86+
public byte[] getPk() {
87+
return pk;
88+
}
89+
90+
public byte[] getSk() {
91+
return sk;
92+
}
93+
94+
public byte[] getCipherText() {
95+
return cipherText;
96+
}
97+
98+
public byte[] getSsk1() {
99+
return ssk1;
100+
}
101+
102+
public byte[] getRnd1() {
103+
return rnd1;
104+
}
105+
106+
public int getAlgorithmType() {
107+
return algorithmType;
108+
}
109+
86110
public EncapsulationModel Encapsulation(byte[] pk){
87111
EncapsulationModel enc;
88112
switch (algorithmType){

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/Kyber1024KeyPairGenerator.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/Kyber1024KeyPair.java

+4-4
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,15 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
import android.os.Build;
44
import android.util.Log;
55
import androidx.annotation.RequiresApi;
66
import com.github.aelstad.keccakj.fips202.SHA3_256;
7-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.Indcpa;
8-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.KyberParams;
7+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.Indcpa;
8+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.KyberParams;
99
import java.security.*;
1010
import java.util.ArrayList;
1111

12-
public final class Kyber1024KeyPairGenerator {
12+
public final class Kyber1024KeyPair {
1313

1414

1515
@RequiresApi(api = Build.VERSION_CODES.O)

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/Kyber512KeyPairGenerator.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/Kyber512KeyPair.java

+4-4
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,14 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
import android.os.Build;
44
import androidx.annotation.RequiresApi;
55
import com.github.aelstad.keccakj.fips202.SHA3_256;
6-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.Indcpa;
7-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.KyberParams;
6+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.Indcpa;
7+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.KyberParams;
88
import java.security.*;
99
import java.util.ArrayList;
1010

11-
public final class Kyber512KeyPairGenerator {
11+
public final class Kyber512KeyPair {
1212

1313
@RequiresApi(api = Build.VERSION_CODES.O)
1414
public static KyberKeyPair generateKeys512() {

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/Kyber768KeyPairGenerator.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/Kyber768KeyPair.java

+4-4
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,15 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
import android.os.Build;
44
import android.util.Log;
55
import androidx.annotation.RequiresApi;
66
import com.github.aelstad.keccakj.fips202.SHA3_256;
7-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.Indcpa;
8-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.KyberParams;
7+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.Indcpa;
8+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.KyberParams;
99
import java.security.*;
1010
import java.util.ArrayList;
1111

12-
public final class Kyber768KeyPairGenerator {
12+
public final class Kyber768KeyPair {
1313

1414
@RequiresApi(api = Build.VERSION_CODES.O)
1515
public static KyberKeyPair generateKeys768( ) {

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/KyberKeyPair.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/KyberKeyPair.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
public class KyberKeyPair {
44
private byte[] kyberPublicKey,kyberPrivateKey;

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/KyberKeySize.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/KyberKeySize.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
public enum KyberKeySize {
44
KEY_512("2"),

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/KyberKeyUtil.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/KyberKeyUtil.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
public final class KyberKeyUtil {
44

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/KyberProcess.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/KyberProcess.java

+3-3
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,11 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
import com.github.aelstad.keccakj.core.KeccakSponge;
44
import com.github.aelstad.keccakj.fips202.SHA3_256;
55
import com.github.aelstad.keccakj.fips202.SHA3_512;
66
import com.github.aelstad.keccakj.fips202.Shake256;
7-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.Indcpa;
8-
import com.sak.pqclibary.kyber.kyberencryption.provider.kyber.KyberParams;
7+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.Indcpa;
8+
import com.sak.pqclibrary.kyber.kyberencryption.provider.kyber.KyberParams;
99
import java.security.MessageDigest;
1010

1111
public class KyberProcess {

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/KyberPublicKeySpec.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/KyberPublicKeySpec.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
import java.math.BigInteger;
44

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/KyberSecretKey.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/KyberSecretKey.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider;
22

33
public class KyberSecretKey {
44
private byte[] secretKey;

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/ByteOps.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/ByteOps.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22

33
import java.util.Arrays;
44

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/Indcpa.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/Indcpa.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22

33
import android.os.Build;
44
import androidx.annotation.RequiresApi;

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/KyberParams.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/KyberParams.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22

33
public final class KyberParams {
44
public final static int paramsN = 256;

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/KyberUniformRandom.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/KyberUniformRandom.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22

33
public final class KyberUniformRandom {
44
private short[] uniformR;

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/Ntt.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/Ntt.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22
public final class Ntt {
33
public static short[] nttZetas = new short[]{
44
2285, 2571, 2970, 1812, 1493, 1422, 287, 202, 3158, 622, 1577, 182, 962,

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/Poly.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/Poly.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22

33
import java.util.Arrays;
44
public final class Poly {

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/UnpackedCipherText.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/UnpackedCipherText.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22

33

44
final class UnpackedCipherText {

app/src/main/java/com/sak/pqclibary/kyber/kyberencryption/provider/kyber/UnpackedPublicKey.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/kyber/kyberencryption/provider/kyber/UnpackedPublicKey.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
package com.sak.pqclibary.kyber.kyberencryption.provider.kyber;
1+
package com.sak.pqclibrary.kyber.kyberencryption.provider.kyber;
22

33

44
final class UnpackedPublicKey {

app/src/main/java/com/sak/pqclibary/ntru/NTRUKem.java renamed to PQCLibrary/src/main/java/com/sak/pqclibrary/ntru/NTRUKem.java

+3-3
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
1-
package com.sak.pqclibary.ntru;
1+
package com.sak.pqclibrary.ntru;
22

3-
import com.sak.pqclibary.saber.models.EncapsulationModel;
4-
import com.sak.pqclibary.saber.models.Keys;
3+
import com.sak.pqclibrary.saber.models.EncapsulationModel;
4+
import com.sak.pqclibrary.saber.models.Keys;
55

66
public class NTRUKem {
77
public static Keys crypto_kem_keypair(){

0 commit comments

Comments
 (0)