Skip to content

gaiuszzang/EncryptHelper

Repository files navigation

EncryptHelper

Release
This library offers a Encrypt & Decrypt Utils. It uses KeyStore internally, so keys are protected by Android System.

example


Including in your project

Add below codes to settings.gradle.

dependencyResolutionManagement {
    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
    repositories {
        maven { url "https://jitpack.io" }
    }
}

And add a dependency code to your module's build.gradle file.

dependencies {
    implementation 'io.groovin:EncryptHelper:x.x.x'
}

How to use

Create EncryptHelper instance with key alias.

val encryptHelper = EncryptHelper("sample_app_key_alias")

You can set up other Key Type.

val encryptHelper = EncryptHelper(
    keyAlias = "sample_app_key_alias",
    keyType = KeyType.RSA_ECB_PKCS1_4096
)

See the following KeyTypes.

  • KeyType.RSA_ECB_PKCS1_2048(default) : RSA Algorithm, ECB Block Mode, PKCS1 Padding, Key Length 2048bit
  • KeyType.RSA_ECB_PKCS1_4096 : RSA Algorithm, ECB Block Mode, PKCS1 Padding, Key Length 4096bit

Use the toEncrypt(), toDecrypt() method for encryption or decryption.

val originalText = "Hello, World!"
val encryptText = encryptHelper.toEncrypt(originalText)
val decryptText = encryptHelper.toDecrypt(encryptText)

License

Copyright 2022 gaiuszzang (Mincheol Shin)

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.