Logo

0x3d.Site

is designed for aggregating information.
Welcome
check repository here

Consent

At a Glance

Consent is a library that makes permissions management in Android significantly easier.

How to Get Started

Add jitpack.io repository to your project:

allprojects {
    repositories {
        jcenter()
        maven {
	    url "https://jitpack.io"
	}
    }
}

Then add Consent to dependencies list:

dependencies {
    implementation 'com.github.igormatyushkin014:Consent:1.2'
}

Requirements

  • Android SDK 23 and later
  • Android Studio 3.3 and later
  • Kotlin 1.3.20 or later

Usage

The main idea of Consent library is to keep all things as simple as possible. That's why all methods are available directly from Activity and Context instances.

You can use string permissions from Manifest.permission collection or special Permission type. Example:

val stringPermission = Manifest.permission.CAMERA
val permission = Permission.CAMERA

All public methods in the library give you a freedom to choose whether you want to use string values or built-in permissions. The Permission class gives you a little more flexibility, but you always can decide whether you need it.

Check Permissions

Lambda syntax:

checkConsent(
    Permission.CAMERA,
    Permission.WRITE_EXTERNAL_STORAGE
).whenFinished { result ->
    if (result.hasBlocked) {
        /*
         * Some permissions are blocked.
         * Let's learn how to retrieve them.
         */
        result.blocked // Contains blocked permissions
        result.allowed // Contains available permissions
    } else {
        // All permissions are available
    }
}

Regular syntax:

val result = checkConsent(
    Permission.CAMERA,
    Permission.WRITE_EXTERNAL_STORAGE
).result

if (result.hasBlocked) {
    // Handle blocked permissions
} else {
    // All permissions are available
}

Another example of regular syntax:

val allowedAccess = !checkConsent(
    Manifest.permission.CAMERA,
    Manifest.permission.WRITE_EXTERNAL_STORAGE
).result.hasBlocked

if (allowedAccess) {
    // All permissions are available
} else {
    // Show warning to user
}

Both syntaxes are equivalent to each other and interchangeable. In other words, both of them return the same result. That's up to you which one to use.

Request Permissions

The same as previous example but replace checkConsent with getConsent:

getConsent(
    Permission.CAMERA,
    Permission.WRITE_EXTERNAL_STORAGE
).whenFinished { result ->
    // Handle the result
}

Also, you have to override activity's onRequestPermissionsResult() method:

override fun onRequestPermissionsResult(
    requestCode: Int,
    permissions: Array<out String>,
    grantResults: IntArray
) {
    handleConsent(
        requestCode,
        permissions,
        grantResults
    )
}

Now, you're all set 🎉🎉🎉

Syntactic sugar

Since version 1.2 you can also check permissions directly from Permission object:

val result = Permission.CAMERA.checkConsent(
    this
).result

Also, from array:

val result = arrayOf(
    Permission.CAMERA,
    Permission.WRITE_EXTERNAL_STORAGE
).checkConsent(this).result

Lambda version:

arrayOf(
    Permission.CAMERA,
    Permission.WRITE_EXTERNAL_STORAGE
).checkConsent(this).whenFinished { result ->
    // Handle result
}

You can also request for single permission in similar way:

// Request single permission

Permission.CAMERA.getConsent(
    this
).whenFinished { result ->
    // Handle result
}

Request for multiple permissions:

arrayOf(
    Permission.CAMERA,
    Permission.WRITE_EXTERNAL_STORAGE
).getConsent(this).whenFinished { result ->
    // Handle result
}

License

Consent is available under the Apache 2.0 license. See the LICENSE file for more info.

Kotlin
Kotlin
Kotlin is a modern programming language interoperable with Java, designed for Android development. It offers a concise syntax and powerful features like null safety and coroutines, streamlining app development.
Kotlin | The Kotlin Blog
Kotlin | The Kotlin Blog
Build software better, together
Build software better, together
Build software better, together
Build software better, together
GitHub - z-huang/InnerTune: A Material 3 YouTube Music client for Android
GitHub - z-huang/InnerTune: A Material 3 YouTube Music client for Android
Build software better, together
Build software better, together
quasar/quasar-kotlin at master · puniverse/quasar
quasar/quasar-kotlin at master · puniverse/quasar
Kotlin Programming Language
Kotlin Programming Language
GitHub - KotatsuApp/Kotatsu: Manga reader for Android
GitHub - KotatsuApp/Kotatsu: Manga reader for Android
GitHub - iamr0s/Dhizuku: A Android Application for share DeviceOwner
GitHub - iamr0s/Dhizuku: A Android Application for share DeviceOwner
Kotlin: An Illustrated Guide
Kotlin: An Illustrated Guide
GitHub - cansik/kotlin-latex-listing: A syntax highlighting template for the Kotlin language in LaTeX listings.
GitHub - cansik/kotlin-latex-listing: A syntax highlighting template for the Kotlin language in LaTeX listings.
GitHub - qwertukg/xml-builder: Simplest XML builder for Kotlin
GitHub - qwertukg/xml-builder: Simplest XML builder for Kotlin
GitHub - cesarferreira/kotlin-pluralizer: :sunny: Kotlin extension to pluralize and singularize strings
GitHub - cesarferreira/kotlin-pluralizer: :sunny: Kotlin extension to pluralize and singularize strings
Kotlin Cheat Sheet
Kotlin Cheat Sheet
GitHub - vert-x3/vertx-lang-kotlin: Vert.x for Kotlin
GitHub - vert-x3/vertx-lang-kotlin: Vert.x for Kotlin
GitHub - hotchemi/khronos: An intuitive Date extensions in Kotlin.
GitHub - hotchemi/khronos: An intuitive Date extensions in Kotlin.
GitHub - icela/FriceEngine: :video_game: JVM game engine based on Swing/JavaFX.
GitHub - icela/FriceEngine: :video_game: JVM game engine based on Swing/JavaFX.
GitHub - holgerbrandl/jsonbuilder: A small artefact to build json with kotlin
GitHub - holgerbrandl/jsonbuilder: A small artefact to build json with kotlin
Kotlin Standard Functions cheat-sheet
Kotlin Standard Functions cheat-sheet
GitHub - MarkusAmshove/Kluent: Fluent Assertion-Library for Kotlin
GitHub - MarkusAmshove/Kluent: Fluent Assertion-Library for Kotlin
GitHub - jershell/kbson: Mongo BSON support for kotlinx.serialization.
GitHub - jershell/kbson: Mongo BSON support for kotlinx.serialization.
GitHub - sepatel/tekniq: A framework designed around Kotlin providing Restful HTTP Client, JDBC DSL, Loading Cache, Configurations, Validations, and more
GitHub - sepatel/tekniq: A framework designed around Kotlin providing Restful HTTP Client, JDBC DSL, Loading Cache, Configurations, Validations, and more
GitHub - Ahoo-Wang/Simba: Distributed lock service | 分布式锁服务
GitHub - Ahoo-Wang/Simba: Distributed lock service | 分布式锁服务
GitHub - JetBrains/intellij-community: IntelliJ IDEA Community Edition & IntelliJ Platform
GitHub - JetBrains/intellij-community: IntelliJ IDEA Community Edition & IntelliJ Platform
GitHub - seniorjoinu/reliable-udp: Multiplexed, coroutine-powered reliable UDP for Kotlin using fountain codes
GitHub - seniorjoinu/reliable-udp: Multiplexed, coroutine-powered reliable UDP for Kotlin using fountain codes
GitHub - hypercube1024/firefly: Firefly is an asynchronous web framework for rapid development of high-performance web application.
GitHub - hypercube1024/firefly: Firefly is an asynchronous web framework for rapid development of high-performance web application.
GitHub - davidepianca98/KMQTT: Kotlin Multiplatform MQTT client & embeddable and standalone broker
GitHub - davidepianca98/KMQTT: Kotlin Multiplatform MQTT client & embeddable and standalone broker
GitHub - L-Briand/KTM: Mustache template engine in kotlin multiplatform
GitHub - L-Briand/KTM: Mustache template engine in kotlin multiplatform
GitHub - sergeshustoff/dikt: Simple and powerful DI for kotlin multiplatform
GitHub - sergeshustoff/dikt: Simple and powerful DI for kotlin multiplatform
GitHub - ParserKt/ParserKt: Naive one-pass recursive descent, scannerless parser framework for Kotlin
GitHub - ParserKt/ParserKt: Naive one-pass recursive descent, scannerless parser framework for Kotlin
Kotlin
More on Kotlin

Programming Tips & Tricks

Code smarter, not harder—insider tips and tricks for developers.

Error Solutions

Turn frustration into progress—fix errors faster than ever.

Shortcuts

The art of speed—shortcuts to supercharge your workflow.
  1. Collections 😎
  2. Frequently Asked Question's 🤯

Tools

available to use.

Made with ❤️

to provide resources in various ares.