[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-7301":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":16,"stars7d":17,"stars30d":18,"stars90d":16,"forks30d":16,"starsTrendScore":19,"compositeScore":20,"rankGlobal":10,"rankLanguage":10,"license":21,"archived":22,"fork":22,"defaultBranch":23,"hasWiki":22,"hasPages":24,"topics":25,"createdAt":10,"pushedAt":10,"updatedAt":43,"readmeContent":44,"aiSummary":45,"trendingCount":16,"starSnapshotCount":16,"syncStatus":19,"lastSyncTime":46,"discoverSource":47},7301,"AboutLibraries","mikepenz\u002FAboutLibraries","mikepenz","AboutLibraries automatically collects all dependencies and licenses of any gradle project (Kotlin MultiPlatform), and provides easy to integrate UI components for Android and Compose Multiplatform environments ","http:\u002F\u002Fmikepenz.github.io\u002FAboutLibraries\u002F",null,"Kotlin",4333,563,135,4,0,8,49,2,30.25,"Apache License 2.0",false,"develop",true,[26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,7,41,42],"aboutlibraries","android","android-development","android-library","android-ui","cmp","compose","compose-multiplatform","fragments","kmp","kmp-library","kotlin","kotlin-multiplatform","kotlin-multiplatform-library","libraries","multiplatform","wasm","2026-06-12 02:01:37","# AboutLibraries\n\n\u003C!-- Badges -->\n[![Maven Central](https:\u002F\u002Fimg.shields.io\u002Fmaven-central\u002Fv\u002Fcom.mikepenz\u002Faboutlibraries-core?style=for-the-badge)](https:\u002F\u002Fsearch.maven.org\u002Fartifact\u002Fcom.mikepenz\u002Faboutlibraries-core)\n[![Gradle Plugin Portal](https:\u002F\u002Fimg.shields.io\u002Fgradle-plugin-portal\u002Fv\u002Fcom.mikepenz.aboutlibraries.plugin?label=Gradle%20Plugin&style=for-the-badge)](https:\u002F\u002Fplugins.gradle.org\u002Fplugin\u002Fcom.mikepenz.aboutlibraries.plugin)\n[![Apache 2.0 License](https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Flicense\u002Fmikepenz\u002FAboutLibraries?style=for-the-badge)](https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries\u002Fblob\u002Fdevelop\u002FLICENSE)\n\nThis library collects dependency details, including licenses at compile time, and offers simple APIs to visualize these in the app.\n*No runtime overhead.* Strong caching. Supports any Gradle dependency.\n\n-------\n\n\u003Cp align=\"center\">\n    \u003Ca href=\"#whats-included-\">What's Included 🚀\u003C\u002Fa> &bull;\n    \u003Ca href=\"#setup\">Setup Guide 🛠️\u003C\u002Fa> &bull;\n    \u003Ca href=\"#gradle-api\">Gradle Tasks ⚙️\u003C\u002Fa> &bull;\n    \u003Ca href=\"MIGRATION.md\">Migration Guide 🧬\u003C\u002Fa> &bull;\n\u003C\u002Fp>\n\n-------\n\n### What's included 🚀\n\n- Kotlin Multiplatform support (including wasm)\n- Lightweight multiplatform core module\n    - Access all generated information\n    - Build custom UIs\n- Compose UI module\n- Gradle Plugin\n    - Generating dependency \u002F license metadata\n    - Different exports, compliance report\n    - Identify possible project funding\n    - License *strict mode*\n- Simple and fast integration\n\n# Screenshots\n\n![AboutLibraries Screenshots](https:\u002F\u002Fraw.githubusercontent.com\u002Fmikepenz\u002FAboutLibraries\u002Fdevelop\u002FDEV\u002Fscreenshots\u002FScreenshots.png)\n\n# Setup\n\n## Latest releases 🛠\n\n- Compose 1.10.x | AGP 9 | [v14.1.0](https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries\u002Ftree\u002F14.1.0)\n- Compose 1.10.x | [v13.2.1](https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries\u002Ftree\u002F13.2.1)\n- Compose 1.9.x | Split Gradle Plugin | [v13.1.0](https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries\u002Ftree\u002F13.1.0)\n\n## Gradle Plugin\n\nThis is the *recommended* way of using the plugin. It provides tasks to generate the meta data used by the ui plugin.\nNote: It will not automatically generate the meta-data. For Android see the android specific plugin.\n\n> The Gradle plugin is hosted via the [Gradle Plugin Portal](https:\u002F\u002Fplugins.gradle.org\u002Fplugin\u002Fcom.mikepenz.aboutlibraries.plugin).\n> Using the `plugins` DSL is the recommended approach.\n\n> [!IMPORTANT]  \n> In v13.x.y, the Gradle Plugin was split into two separate plugins:\n>\n> 1. **Main Plugin** (`com.mikepenz.aboutlibraries.plugin`): Provides manual tasks for generating library definitions\n> 2. **Android Plugin** (`com.mikepenz.aboutlibraries.plugin.android`): Automatically hooks into the Android build process\n>\n> For most projects, the main plugin is recommended. Only use the Android plugin if you specifically need the library definitions to be generated as part of the Android build\n> process.\n>\n> See the [migration guide](MIGRATION.md) for more details.\n\n\u003Cdetails open>\u003Csummary>\u003Cb>Using the plugins DSL (Recommended)\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n## Default Gradle Plugin - Multiplatform\n\n```kts\n\u002F\u002F Root build.gradle.kts\nid(\"com.mikepenz.aboutlibraries.plugin\") version \"${latestAboutLibsRelease}\" apply false\n\n\u002F\u002F App build.gradle.kts\nid(\"com.mikepenz.aboutlibraries.plugin\")\n```\n\n## Gradle Plugin - Android\n\nTo improve configuration cache compatibility and reduce unintended behavior, the auto registering as part of the Android build was moved into its own plugin in v13.x.y.\n\n```kotlin\n\u002F\u002F Root build.gradle.kts\nid(\"com.mikepenz.aboutlibraries.plugin.android\") version \"${latestAboutLibsRelease}\" apply false\n\n\u002F\u002F App build.gradle.kts\nid(\"com.mikepenz.aboutlibraries.plugin.android\")\n```\n\nWhen using the `.android` plugin variant:\n\n- The library definitions are automatically generated as part of the Android build process\n- The `registerAndroidTasks` configuration no longer exists, as it now happens by default\n- The generated file is automatically included in your Android resources\n- No manual execution of tasks is required\n\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n\u003Cdetails>\u003Csummary>\u003Cb>Using the plugins DSL (Apply to all subprojects)\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n```kts\n\u002F\u002F Root build.gradle\nid(\"com.mikepenz.aboutlibraries.plugin\") version \"${latestAboutLibsRelease}\"\n```\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n\u003Cdetails>\u003Csummary>\u003Cb>Using legacy plugin application\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n```gradle\n\u002F\u002F Root build.gradle\nclasspath(\"com.mikepenz.aboutlibraries.plugin:aboutlibraries-plugin:${latestAboutLibsRelease}\")\n\n\u002F\u002F App build.gradle\napply plugin: 'com.mikepenz.aboutlibraries.plugin'\n```\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n\u003Cdetails>\u003Csummary>\u003Cb>Gradle Plugin Configuration Options\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n## Gradle Plugin Configuration\n\nThe plugin allows customization via the `aboutLibraries` extension in your build script.\n\n```kts\naboutLibraries {\n    \u002F\u002F Allow to enable \"offline mode\", will disable any network check of the plugin (including [fetchRemoteLicense] or pulling spdx license texts)\n    offlineMode = false\n\n    collect {\n        \u002F\u002F Define the path configuration files are located in. E.g. additional libraries, licenses to add to the target .json\n        \u002F\u002F Warning: Please do not use the parent folder of a module as path, as this can result in issues. More details: https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries\u002Fissues\u002F936\n        \u002F\u002F The path provided is relative to the modules path (not project root)\n        configPath = file(\"..\u002Fconfig\")\n\n        \u002F\u002F (optional) GitHub token to raise API request limit to allow fetching more licenses\n        gitHubApiToken = if (hasProperty(\"github.pat\")) property(\"github.pat\")?.toString() else null\n\n        \u002F\u002F Enable fetching of \"remote\" licenses.  Uses the API of supported source hosts\n        \u002F\u002F See https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries#special-repository-support\n        \u002F\u002F A `gitHubApiToken` is required for this to work as it fetches information from GitHub's API.\n        fetchRemoteLicense = false\n\n        \u002F\u002F Enables fetching of \"remote\" funding information. Uses the API of supported source hosts\n        \u002F\u002F See https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries#special-repository-support\n        \u002F\u002F A `gitHubApiToken` is required for this to work as it fetches information from GitHub's API.\n        fetchRemoteFunding = false\n\n        \u002F\u002F Allows to only collect dependencies of specific variants during the `collectDependencies` step.\n        \u002F\u002F filterVariants.addAll(\"debug\", \"release\")\n\n        \u002F\u002F Enable inclusion of `platform` dependencies in the library report\n        includePlatform = true\n    }\n\n    export {\n        \u002F\u002F Define the output path (including fileName). Modifying this will disable the automatic meta data discovery for supported platforms.\n        outputFile = file(\"src\u002FcommonMain\u002FcomposeResources\u002Ffiles\u002Faboutlibraries.json\")\n\n        \u002F\u002F The default export variant to use for this module.\n        \u002F\u002F variant = \"release\"\n\n        \u002F\u002F Allows to exclude some fields from the generated meta data field.\n        \u002F\u002F If the class name is specified, the field is only excluded for that class; without a class name, the exclusion is global.\n        excludeFields.addAll(\"License.name\", \"developers\", \"funding\")\n\n        \u002F\u002F Enable pretty printing for the generated JSON file\n        prettyPrint = true\n    }\n\n    exports {\n        \u002F\u002F Define export configuration per variant.\n        create(\"jvm\") {\n            outputFile = file(\"files\u002Fjvm\u002Faboutlibraries.json\")\n        }\n        create(\"wasmJs\") {\n            outputFile = file(\"files\u002FwasmJs\u002Faboutlibraries.json\")\n        }\n    }\n\n    license {\n        \u002F\u002F Define the strict mode, will fail if the project uses licenses not allowed\n        \u002F\u002F - This will only automatically fail for Android projects using the Android-specific plugin (com.mikepenz.aboutlibraries.plugin.android)\n        \u002F\u002F For other projects, execute `exportLibraryDefinitions` manually\n        strictMode = com.mikepenz.aboutlibraries.plugin.StrictMode.FAIL\n\n        \u002F\u002F Allowed set of licenses, this project will be able to use without build failure\n        allowedLicenses.addAll(\"Apache-2.0\", \"asdkl\")\n\n        \u002F\u002F Allowed set of licenses for specific dependencies, this project will be able to use without build failure\n        allowedLicensesMap = mapOf(\n            \"asdkl\" to listOf(\"androidx.jetpack.library\"),\n            \"NOASSERTION\" to listOf(\"org.jetbrains.kotlinx\"),\n        )\n\n        \u002F\u002F Full license text for license IDs mentioned here will be included, even if no detected dependency uses them.\n        \u002F\u002F additionalLicenses.addAll(\"mit\", \"mpl_2_0\")\n    }\n\n    library {\n        \u002F\u002F Enable the duplication mode, allows to merge, or link dependencies which relate\n        duplicationMode = com.mikepenz.aboutlibraries.plugin.DuplicateMode.MERGE\n        \u002F\u002F Configure the duplication rule, to match \"duplicates\" with\n        duplicationRule = com.mikepenz.aboutlibraries.plugin.DuplicateRule.SIMPLE\n    }\n}\n```\n\nFull documentation of all available gradle plugin\nconfigurations can be found in\nthe [AboutLibrariesExtension.kt](https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries\u002Fblob\u002Fdevelop\u002Fplugin-build\u002Fplugin\u002Fsrc\u002Fmain\u002Fkotlin\u002Fcom\u002Fmikepenz\u002Faboutlibraries\u002Fplugin\u002FAboutLibrariesExtension.kt)\nsource file.\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n\u003Cdetails>\u003Csummary>\u003Cb>Modify Libraries \u002F Licenses\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n## Modify libraries \u002F licenses\n\nThe plugin offers the ability to add or override library and license details by placing JSON files\nin the `libraries` and `licenses` directories within the configured `configPath`.\nSee the [config directory](https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FAboutLibraries\u002Fblob\u002Fdevelop\u002Fconfig\u002F) for examples.\n\n## Provide funding information\n\nThe plugin offers the ability to add or override funding details by placing a `funding.json` JSON file in the `funding` directory within the configured `configPath`.\nAlternatively the `exportFunding` task can be used to generate this data automatically (ensure to provide a GitHub API Key).\nThe task will automatically write the file in the respective folder. Note: It will overwrite the file if it already exists.\n\n```bash\n.\u002Fgradlew app:exportFunding\n```\n\n### Libraries\n\nProvide additional or modify existing libraries via a `.json` file per library.\nIf the `uniqueId` overlaps, a merge will occur.\n\n```json\n{\n  \"uniqueId\": \"com.mikepenz:materialdrawer\",\n  \"developers\": [\n    {\n      \"name\": \"Mike Penz\",\n      \"organisationUrl\": \"https:\u002F\u002Fmikepenz.dev\"\n    }\n  ],\n  \"description\": \"(Merged) The flexible, easy to use, all in one drawer library for your Android project.\",\n  \"name\": \"ABC MaterialDrawer Library\",\n  \"website\": \"https:\u002F\u002Fgithub.com\u002Fmikepenz\u002FMaterialDrawer\"\n}\n```\n\n### Licenses\n\nProvide additional or modify existing licenses via a `.json` file per license.\n\n```json\n{\n  \"content\": \"This is the Android Software Development Kit License Agreement\\n\u003Cbr \u002F>\\n1. Introduction\\n\u003Cbr \u002F>\\n1.1 The Android Software Development Kit (referred to in the License Agreement as the \\\"SDK\\\" and specifically including the Android system files, packaged APIs, and Google APIs add-ons) is licensed to you subject to the terms of the License Agreement. The License Agreement forms a legally binding contract between you and Google in relation to your use of the SDK.\\n\u003Cbr \u002F>\\n1.2 \\\"Android\\\" means the Android software stack for devices, as made available under the Android Open Source Project, which is located at the following URL: http:\u002F\u002Fsource.android.com\u002F, as updated from time to time.\\n\u003Cbr \u002F>\\n1.3 A \\\"compatible implementation\\\" means any Android device that (i) complies with the Android Compatibility Definition document, which can be found at the Android compatibility website (http:\u002F\u002Fsource.android.com\u002Fcompatibility) and which may be updated from time to time; and (ii) successfully passes the Android Compatibility Test Suite (CTS).\\n\u003Cbr \u002F>\\n1.4 \\\"Google\\\" means Google LLC, a Delaware corporation with principal place of business at 1600 Amphitheatre Parkway, Mountain View, CA 94043, United States.\\n\u003Cbr \u002F>\\n2. Accepting this License Agreement\\n\u003Cbr \u002F>\\n2.1 In order to use the SDK, you must first agree to the License Agreement. You may not use the SDK if you do not accept the License Agreement.\\n\u003Cbr \u002F>\\n2.2 By clicking to accept, you hereby agree to the terms of the License Agreement.\\n\u003Cbr \u002F>\\n2.3 You may not use the SDK and may not accept the License Agreement if you are a person barred from receiving the SDK under the laws of the United States or other countries, including the country in which you are resident or from which you use the SDK.\\n\u003Cbr \u002F>\\n2.4 If you are agreeing to be bound by the License Agreement on behalf of your employer or other entity, you represent and warrant that you have full legal authority to bind your employer or such entity to the License Agreement. If you do not have the requisite authority, you may not accept the License Agreement or use the SDK on behalf of your employer or other entity.\\n\u003Cbr \u002F>\\n3. SDK License from Google\\n\u003Cbr \u002F>\\n3.1 Subject to the terms of the License Agreement, Google grants you a limited, worldwide, royalty-free, non-assignable, non-exclusive, and non-sublicensable license to use the SDK solely to develop applications for compatible implementations of Android.\\n\u003Cbr \u002F>\\n3.2 You may not use this SDK to develop applications for other platforms (including non-compatible implementations of Android) or to develop another SDK. You are of course free to develop applications for other platforms, including non-compatible implementations of Android, provided that this SDK is not used for that purpose.\\n\u003Cbr \u002F>\\n3.3 You agree that Google or third parties own all legal right, title and interest in and to the SDK, including any Intellectual Property Rights that subsist in the SDK. \\\"Intellectual Property Rights\\\" means any and all rights under patent law, copyright law, trade secret law, trademark law, and any and all other proprietary rights. Google reserves all rights not expressly granted to you.\\n\u003Cbr \u002F>\\n3.4 You may not use the SDK for any purpose not expressly permitted by the License Agreement.  Except to the extent required by applicable third party licenses, you may not copy (except for backup purposes), modify, adapt, redistribute, decompile, reverse engineer, disassemble, or create derivative works of the SDK or any part of the SDK.\\n\u003Cbr \u002F>\\n3.5 Use, reproduction and distribution of components of the SDK licensed under an open source software license are governed solely by the terms of that open source software license and not the License Agreement.\\n\u003Cbr \u002F>\\n3.6 You agree that the form and nature of the SDK that Google provides may change without prior notice to you and that future versions of the SDK may be incompatible with applications developed on previous versions of the SDK. You agree that Google may stop (permanently or temporarily) providing the SDK (or any features within the SDK) to you or to users generally at Google's sole discretion, without prior notice to you.\\n\u003Cbr \u002F>\\n3.7 Nothing in the License Agreement gives you a right to use any of Google's trade names, trademarks, service marks, logos, domain names, or other distinctive brand features.\\n\u003Cbr \u002F>\\n3.8 You agree that you will not remove, obscure, or alter any proprietary rights notices (including copyright and trademark notices) that may be affixed to or contained within the SDK.\\n\u003Cbr \u002F>\\n4. Use of the SDK by You\\n\u003Cbr \u002F>\\n4.1 Google agrees that it obtains no right, title or interest from you (or your licensors) under the License Agreement in or to any software applications that you develop using the SDK, including any intellectual property rights that subsist in those applications.\\n\u003Cbr \u002F>\\n4.2 You agree to use the SDK and write applications only for purposes that are permitted by (a) the License Agreement and (b) any applicable law, regulation or generally accepted practices or guidelines in the relevant jurisdictions (including any laws regarding the export of data or software to and from the United States or other relevant countries).\\n\u003Cbr \u002F>\\n4.3 You agree that if you use the SDK to develop applications for general public users, you will protect the privacy and legal rights of those users. If the users provide you with user names, passwords, or other login information or personal information, you must make the users aware that the information will be available to your application, and you must provide legally adequate privacy notice and protection for those users. If your application stores personal or sensitive information provided by users, it must do so securely. If the user provides your application with Google Account information, your application may only use that information to access the user's Google Account when, and for the limited purposes for which, the user has given you permission to do so.\\n\u003Cbr \u002F>\\n4.4 You agree that you will not engage in any activity with the SDK, including the development or distribution of an application, that interferes with, disrupts, damages, or accesses in an unauthorized manner the servers, networks, or other properties or services of any third party including, but not limited to, Google or any mobile communications carrier.\\n\u003Cbr \u002F>\\n4.5 You agree that you are solely responsible for (and that Google has no responsibility to you or to any third party for) any data, content, or resources that you create, transmit or display through Android and\u002For applications for Android, and for the consequences of your actions (including any loss or damage which Google may suffer) by doing so.\\n\u003Cbr \u002F>\\n4.6 You agree that you are solely responsible for (and that Google has no responsibility to you or to any third party for) any breach of your obligations under the License Agreement, any applicable third party contract or Terms of Service, or any applicable law or regulation, and for the consequences (including any loss or damage which Google or any third party may suffer) of any such breach.\\n\u003Cbr \u002F>\\n5. Your Developer Credentials\\n\u003Cbr \u002F>\\n5.1 You agree that you are responsible for maintaining the confidentiality of any developer credentials that may be issued to you by Google or which you may choose yourself and that you will be solely responsible for all applications that are developed under your developer credentials.\\n\u003Cbr \u002F>\\n6. Privacy and Information\\n\u003Cbr \u002F>\\n6.1 In order to continually innovate and improve the SDK, Google may collect certain usage statistics from the software including but not limited to a unique identifier, associated IP address, version number of the software, and information on which tools and\u002For services in the SDK are being used and how they are being used. Before any of this information is collected, the SDK will notify you and seek your consent. If you withhold consent, the information will not be collected.\\n\u003Cbr \u002F>\\n6.2 The data collected is examined in the aggregate to improve the SDK and is maintained in accordance with Google's Privacy Policy.\\n\u003Cbr \u002F>\\n7. Third Party Applications\\n\u003Cbr \u002F>\\n7.1 If you use the SDK to run applications developed by a third party or that access data, content or resources provided by a third party, you agree that Google is not responsible for those applications, data, content, or resources. You understand that all data, content or resources which you may access through such third party applications are the sole responsibility of the person from which they originated and that Google is not liable for any loss or damage that you may experience as a result of the use or access of any of those third party applications, data, content, or resources.\\n\u003Cbr \u002F>\\n7.2 You should be aware the data, content, and resources presented to you through such a third party application may be protected by intellectual property rights which are owned by the providers (or by other persons or companies on their behalf). You may not modify, rent, lease, loan, sell, distribute or create derivative works based on these data, content, or resources (either in whole or in part) unless you have been specifically given permission to do so by the relevant owners.\\n\u003Cbr \u002F>\\n7.3 You acknowledge that your use of such third party applications, data, content, or resources may be subject to separate terms between you and the relevant third party. In that case, the License Agreement does not affect your legal relationship with these third parties.\\n\u003Cbr \u002F>\\n8. Using Android APIs\\n\u003Cbr \u002F>\\n8.1 Google Data APIs\\n\u003Cbr \u002F>\\n8.1.1 If you use any API to retrieve data from Google, you acknowledge that the data may be protected by intellectual property rights which are owned by Google or those parties that provide the data (or by other persons or companies on their behalf). Your use of any such API may be subject to additional Terms of Service. You may not modify, rent, lease, loan, sell, distribute or create derivative works based on this data (either in whole or in part) unless allowed by the relevant Terms of Service.\\n\u003Cbr \u002F>\\n8.1.2 If you use any API to retrieve a user's data from Google, you acknowledge and agree that you shall retrieve data only with the user's explicit consent and only when, and for the limited purposes for which, the user has given you permission to do so. If you use the Android Recognition Service API, documented at the following URL: https:\u002F\u002Fdeveloper.android.com\u002Freference\u002Fandroid\u002Fspeech\u002FRecognitionService, as updated from time to time, you acknowledge that the use of the API is subject to the Data Processing Addendum for Products where Google is a Data Processor, which is located at the following URL: https:\u002F\u002Fprivacy.google.com\u002Fbusinesses\u002Fgdprprocessorterms\u002F, as updated from time to time. By clicking to accept, you hereby agree to the terms of the Data Processing Addendum for Products where Google is a Data Processor.\\n\u003Cbr \u002F>\\n9. Terminating this License Agreement\\n\u003Cbr \u002F>\\n9.1 The License Agreement will continue to apply until terminated by either you or Google as set out below.\\n\u003Cbr \u002F>\\n9.2 If you want to terminate the License Agreement, you may do so by ceasing your use of the SDK and any relevant developer credentials.\\n\u003Cbr \u002F>\\n9.3 Google may at any time, terminate the License Agreement with you if:\u003Cbr \u002F>\\n(A) you have breached any provision of the License Agreement; or\u003Cbr \u002F>\\n(B) Google is required to do so by law; or\u003Cbr \u002F>\\n(C) the partner with whom Google offered certain parts of SDK (such as APIs) to you has terminated its relationship with Google or ceased to offer certain parts of the SDK to you; or\u003Cbr \u002F>\\n(D) Google decides to no longer provide the SDK or certain parts of the SDK to users in the country in which you are resident or from which you use the service, or the provision of the SDK or certain SDK services to you by Google is, in Google's sole discretion, no longer commercially viable.\u003Cbr \u002F>\\n\u003Cbr \u002F>\\n9.4 When the License Agreement comes to an end, all of the legal rights, obligations and liabilities that you and Google have benefited from, been subject to (or which have accrued over time whilst the License Agreement has been in force) or which are expressed to continue indefinitely, shall be unaffected by this cessation, and the provisions of paragraph 14.7 shall continue to apply to such rights, obligations and liabilities indefinitely.\\n\u003Cbr \u002F>\\n10. DISCLAIMER OF WARRANTIES\\n\u003Cbr \u002F>\\n10.1 YOU EXPRESSLY UNDERSTAND AND AGREE THAT YOUR USE OF THE SDK IS AT YOUR SOLE RISK AND THAT THE SDK IS PROVIDED \\\"AS IS\\\" AND \\\"AS AVAILABLE\\\" WITHOUT WARRANTY OF ANY KIND FROM GOOGLE.\\n\u003Cbr \u002F>\\n10.2 YOUR USE OF THE SDK AND ANY MATERIAL DOWNLOADED OR OTHERWISE OBTAINED THROUGH THE USE OF THE SDK IS AT YOUR OWN DISCRETION AND RISK AND YOU ARE SOLELY RESPONSIBLE FOR ANY DAMAGE TO YOUR COMPUTER SYSTEM OR OTHER DEVICE OR LOSS OF DATA THAT RESULTS FROM SUCH USE.\\n\u003Cbr \u002F>\\n10.3 GOOGLE FURTHER EXPRESSLY DISCLAIMS ALL WARRANTIES AND CONDITIONS OF ANY KIND, WHETHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO THE IMPLIED WARRANTIES AND CONDITIONS OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.\\n\u003Cbr \u002F>\\n11. LIMITATION OF LIABILITY\\n\u003Cbr \u002F>\\n11.1 YOU EXPRESSLY UNDERSTAND AND AGREE THAT GOOGLE, ITS SUBSIDIARIES AND AFFILIATES, AND ITS LICENSORS SHALL NOT BE LIABLE TO YOU UNDER ANY THEORY OF LIABILITY FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, CONSEQUENTIAL OR EXEMPLARY DAMAGES THAT MAY BE INCURRED BY YOU, INCLUDING ANY LOSS OF DATA, WHETHER OR NOT GOOGLE OR ITS REPRESENTATIVES HAVE BEEN ADVISED OF OR SHOULD HAVE BEEN AWARE OF THE POSSIBILITY OF ANY SUCH LOSSES ARISING.\\n\u003Cbr \u002F>\\n12. Indemnification\\n\u003Cbr \u002F>\\n12.1 To the maximum extent permitted by law, you agree to defend, indemnify and hold harmless Google, its affiliates and their respective directors, officers, employees and agents from and against any and all claims, actions, suits or proceedings, as well as any and all losses, liabilities, damages, costs and expenses (including reasonable attorneys fees) arising out of or accruing from (a) your use of the SDK, (b) any application you develop on the SDK that infringes any copyright, trademark, trade secret, trade dress, patent or other intellectual property right of any person or defames any person or violates their rights of publicity or privacy, and (c) any non-compliance by you with the License Agreement.\\n\u003Cbr \u002F>\\n13. Changes to the License Agreement\\n\u003Cbr \u002F>\\n13.1 Google may make changes to the License Agreement as it distributes new versions of the SDK. When these changes are made, Google will make a new version of the License Agreement available on the website where the SDK is made available.\\n\u003Cbr \u002F>\\n14. General Legal Terms\\n\u003Cbr \u002F>\\n14.1 The License Agreement constitutes the whole legal agreement between you and Google and governs your use of the SDK (excluding any services which Google may provide to you under a separate written agreement), and completely replaces any prior agreements between you and Google in relation to the SDK.\\n\u003Cbr \u002F>\\n14.2 You agree that if Google does not exercise or enforce any legal right or remedy which is contained in the License Agreement (or which Google has the benefit of under any applicable law), this will not be taken to be a formal waiver of Google's rights and that those rights or remedies will still be available to Google.\\n\u003Cbr \u002F>\\n14.3 If any court of law, having the jurisdiction to decide on this matter, rules that any provision of the License Agreement is invalid, then that provision will be removed from the License Agreement without affecting the rest of the License Agreement. The remaining provisions of the License Agreement will continue to be valid and enforceable.\\n\u003Cbr \u002F>\\n14.4 You acknowledge and agree that each member of the group of companies of which Google is the parent shall be third party beneficiaries to the License Agreement and that such other companies shall be entitled to directly enforce, and rely upon, any provision of the License Agreement that confers a benefit on (or rights in favor of) them. Other than this, no other person or company shall be third party beneficiaries to the License Agreement.\\n\u003Cbr \u002F>\\n14.5 EXPORT RESTRICTIONS. THE SDK IS SUBJECT TO UNITED STATES EXPORT LAWS AND REGULATIONS. YOU MUST COMPLY WITH ALL DOMESTIC AND INTERNATIONAL EXPORT LAWS AND REGULATIONS THAT APPLY TO THE SDK. THESE LAWS INCLUDE RESTRICTIONS ON DESTINATIONS, END USERS AND END USE.\\n\u003Cbr \u002F>\\n14.6 The rights granted in the License Agreement may not be assigned or transferred by either you or Google without the prior written approval of the other party. Neither you nor Google shall be permitted to delegate their responsibilities or obligations under the License Agreement without the prior written approval of the other party.\\n\u003Cbr \u002F>\\n14.7 The License Agreement, and your relationship with Google under the License Agreement, shall be governed by the laws of the State of California without regard to its conflict of laws provisions. You and Google agree to submit to the exclusive jurisdiction of the courts located within the county of Santa Clara, California to resolve any legal matter arising from the License Agreement. Notwithstanding this, you agree that Google shall still be allowed to apply for injunctive remedies (or an equivalent type of urgent legal relief) in any jurisdiction.\",\n  \"hash\": \"asdkl\",\n  \"url\": \"https:\u002F\u002Fdeveloper.android.com\u002Fstudio\u002Fterms.html\",\n  \"name\": \"Android Software Development Kit License Agreement\"\n}\n```\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n\u003Cdetails>\u003Csummary>\u003Cb>Optimized Resource Shrinking \u002F AGP 9.0\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n## Optimized Resource Shrinking \u002F AGP 9.0\n\nWhen [optimized resource shrinking](https:\u002F\u002Fdeveloper.android.com\u002Ftopic\u002Fperformance\u002Fapp-optimization\u002Fenable-app-optimization#optimized-resource-shrinking-2)\nis enabled — or when using AGP 9.0, where it is enabled by default — the generated \n`aboutlibraries.json` file may be removed during the shrinking step. To prevent this, add \na [resource keep file](https:\u002F\u002Fdeveloper.android.com\u002Ftopic\u002Fperformance\u002Fapp-optimization\u002Fcustomize-which-resources-to-keep)\nwith the following contents:\n\n```xml\n\u003C?xml version=\"1.0\" encoding=\"utf-8\"?>\n\u003Cresources xmlns:tools=\"http:\u002F\u002Fschemas.android.com\u002Ftools\"\n    tools:keep=\"@raw\u002Faboutlibraries\" \u002F>\n```\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n## Dependencies\n\n> The AboutLibraries libraries are published to [Maven Central](https:\u002F\u002Fsearch.maven.org\u002Fartifact\u002Fcom.mikepenz\u002Faboutlibraries-core).\n> Using a version catalog (`libs.versions.toml`) is the recommended way to manage dependencies.\n\n### `libs.versions.toml` (Recommended)\n\n```toml\n[versions]\naboutLibraries = \"{latest-version}\"\n\n[libraries]\n# Core module (required for accessing library data)\naboutlibraries-core = { module = \"com.mikepenz:aboutlibraries-core\", version.ref = \"aboutLibraries\" }\n# Compose UI modules (choose one or both)\naboutlibraries-compose-core = { module = \"com.mikepenz:aboutlibraries-compose-core\", version.ref = \"aboutLibraries\" } # Common compose core\naboutlibraries-compose-m2 = { module = \"com.mikepenz:aboutlibraries-compose\", version.ref = \"aboutLibraries\" }      # Material 2 UI\naboutlibraries-compose-m3 = { module = \"com.mikepenz:aboutlibraries-compose-m3\", version.ref = \"aboutLibraries\" }      # Material 3 UI\n\n[plugins]\naboutLibraries = { id = \"com.mikepenz.aboutlibraries.plugin\", version.ref = \"aboutLibraries\" }\n```\n\n## Core-module\n\nInclude the core module to access the generated library information programmatically.\n\n```gradle\n\u002F\u002F build.gradle.kts\n\u002F\u002F Recommended: Using version catalog\nimplementation(libs.aboutlibraries.core)\n\n\u002F\u002F Alternative: Direct dependency declaration\n\u002F\u002F implementation(\"com.mikepenz:aboutlibraries-core:${latestAboutLibsRelease}\")\n```\n\n\u003Cdetails>\u003Csummary>\u003Cb>(Advanced) Usage\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n## Access generated library details\n\nTo create a individual integration, access the generated library information programmatically\nthrough the core module.\n\n```kotlin\nval libs = Libs.Builder()\n    .withJson(aboutLibsJson) \u002F\u002F provide the metaData (alternative APIs available)\n    .build()\nval libraries = libs.libraries \u002F\u002F retrieve all libraries defined in the metadata\nval licenses = libs.licenses \u002F\u002F retrieve all licenses defined in the metadata\nfor (lib in libraries) {\n    Log.i(\"AboutLibraries\", \"${lib.name}\")\n}\n```\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n## UI-module (Compose)\n\nInclude the Compose UI module(s) for easy integration into Jetpack Compose applications.\n\n```gradle\n\u002F\u002F build.gradle.kts\n\u002F\u002F Recommended: Using version catalog (choose M2 or M3, or both)\nimplementation(libs.aboutlibraries.compose.m2) \u002F\u002F Material 2\nimplementation(libs.aboutlibraries.compose.m3) \u002F\u002F Material 3\n\n\u002F\u002F Alternative: Direct dependency declaration\n\u002F\u002F implementation(\"com.mikepenz:aboutlibraries-compose:${latestAboutLibsRelease}\") \u002F\u002F Material 2\n\u002F\u002F implementation(\"com.mikepenz:aboutlibraries-compose-m3:${latestAboutLibsRelease}\") \u002F\u002F Material 3\n```\n\n### Usage\n\n```kotlin\n\u002F\u002F Android: Provide resource identifier for the `R.raw.aboutlibraries` file.\nval libraries by produceLibraries(R.raw.aboutlibraries)\nLibrariesContainer(libraries, Modifier.fillMaxSize())\n\n\u002F\u002F Multiplatform: Using compose-resources API (e.g., src\u002FcommonMain\u002FcomposeResources\u002Ffiles\u002Faboutlibraries.json)\nval libraries by produceLibraries {\n    Res.readBytes(\"files\u002Faboutlibraries.json\").decodeToString()\n}\nLibrariesContainer(libraries, Modifier.fillMaxSize())\n\n\n\u002F\u002F Multiplatform: Manually loading JSON\nval libraries by produceLibraries {\n    \u002F\u002F Replace with your specific resource loading logic\n    useResource(\"aboutlibraries.json\") { res -> res.bufferedReader().readText() }\n}\nLibrariesContainer(libraries, Modifier.fillMaxSize())\n```\n\n\u003Cdetails>\u003Csummary>\u003Cb>Advanced Usage\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\n### Advanced Usage\n\nProvide custom header, divider, and footer items for the `LibrariesContainer`.\n\n```kotlin\n\u002F\u002F custom header, divider, footer\nLibrariesContainer(\n    libraries = libraries,\n    modifier = Modifier.fillMaxSize().padding(it),\n    header = {\n        item {\n            Box(modifier = Modifier.fillMaxWidth().padding(16.dp), contentAlignment = Alignment.Center) {\n                Text(\"Hello Header\")\n            }\n        }\n    },\n    divider = { HorizontalDivider() },\n    footer = {\n        item {\n            Box(modifier = Modifier.fillMaxWidth().padding(16.dp), contentAlignment = Alignment.Center) {\n                Text(\"Hello Footer\")\n            }\n        }\n    }\n)\n```\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n\n\u003Cdetails>\u003Csummary>\u003Cb>Compose Multiplatform (Desktop, Wasm, etc.)\u003C\u002Fb>\u003C\u002Fsummary>\n\u003Cp>\n\nThe core and compose modules are Kotlin Multiplatform compatible.\nThe `app-desktop` and `app-wasm` modules demonstrate usage outside of Android, including manual generation and inclusion of the dependency metadata.\n\n### Generate Dependency Information\n\nManually export the definitions using the Gradle task. This is typically needed for non-Android platforms or when not using the android specific plugin.\n\n```bash\n# Export definitions to the specified file (e.g., for desktop)\n.\u002Fgradlew :app-desktop:exportLibraryDefinitions -PaboutLibraries.outputFile=src\u002Fmain\u002Fresources\u002Flibraries.json\n\n# Filter exported definition by variant (e.g., for wasmJs target)\n.\u002Fgradlew :app-wasm:exportLibraryDefinitions -PaboutLibraries.outputFile=src\u002FjsMain\u002Fresources\u002Faboutlibraries.json -PaboutLibraries.exportVariant=wasmJs\n```\n\n### Run Demo app(s)\n\n```bash\n# JVM Desktop app\n.\u002Fgradlew :app-desktop:run\n\n# WASM Web app\n.\u002Fgradlew :app-wasm:run\n```\n\n### Screenshot\n\n![Compose Multiplatform Screenshot](https:\u002F\u002Fraw.githubusercontent.com\u002Fmikepenz\u002FAboutLibraries\u002Fdevelop\u002FDEV\u002Fscreenshots\u002Fcompose-jb.png)\n\n\u003C\u002Fp>\n\u003C\u002Fdetails>\n\n## Enterprise \u002F Manual JSON Handling\n\nFor environments requiring full control over the included `aboutlibraries.json` (e.g., manual verification, CI generation), you can handle generation manually.\n\n```kts\n\u002F\u002F build.gradle.kts\naboutLibraries {\n    export {\n        \u002F\u002F Define the output path for manual generation\n        \u002F\u002F Adjust the path based on your project structure (e.g., composeResources, Android res\u002Fraw)\n        outputFile = file(\"src\u002FcommonMain\u002FcomposeResources\u002Ffiles\u002Faboutlibraries.json\")\n        \u002F\u002F Optionally specify the variant for export\n        \u002F\u002F variant = \"release\"\n    }\n}\n```\n\nGenerate the file manually using the Gradle task:\n\n```bash\n# Generate using the configured location and variant\n.\u002Fgradlew :app:exportLibraryDefinitions\n\n# Generate providing a custom path and variant override\n.\u002Fgradlew :app:exportLibraryDefinitions -PaboutLibraries.outputFile=src\u002Fmain\u002Fres\u002Fraw\u002Flibraries.json -PaboutLibraries.exportVariant=release\n```\n\nCommit the generated `aboutlibraries.json` to your SCM. The library will then need to load this file manually. See details in [Usage](#usage).\n\n## Gradle API \u002F Tasks\n\nBy default, the gradle plugin is automatically executed for Android projects, generating the library\nmetadata where it's automatically discovered by the `ui` modules.\nFor other environments or for more advanced usages the plugin offers additional APIs.\n\n```bash\n# Manually generate the dependency metaData in the provided location. Allows to commit it in SCM\n# Exports the metaData in `src\u002Fmain\u002Fresources\u002F` relative to the module root\n.\u002Fgradlew app-desktop:exportLibraryDefinitions -PaboutLibraries.outputFile=src\u002Fmain\u002Fresources\u002Flibraries.json\n# Export only for a specific variant: `release`\n.\u002Fgradlew app-desktop:exportLibraryDefinitions -PaboutLibraries.outputFile=src\u002Fmain\u002Fresources\u002Flibraries.json -PaboutLibraries.exportVariant=release\n\n# Export dependencies to CLI in CSV format\n.\u002Fgradlew app:exportLibraries\n.\u002Fgradlew app:exportLibraries${Variant}\n\n# Outputs all dependencies with name, version and their identifier\n.\u002Fgradlew app:findLibraries\n\n# Exports all dependencies in a format helpful for compliance reports.\n# By default writes `export.csv` and `export.txt` and `dependencies` folder in the root of the project.\n.\u002Fgradlew app:exportComplianceLibraries${Variant} -PaboutLibraries.exportPath=complianceReport\u002F\n\n# List all funding options for included projects (as identified via the e.g.: GitHub API)\n.\u002Fgradlew app:fundLibraries\n```\n\n# Special repository support\n\n| Host                          | License | Funding |\n|-------------------------------|---------|---------|\n| [GitHub](https:\u002F\u002Fgithub.com\u002F) | x       | x       |\n\n# Disclaimer\n\nThis library uses all compile time dependencies (and their sub dependencies) as defined in the\n`build.gradle` file.\nThis could lead to dependencies which are only used during compilation (and not actually distributed\nin the app) to be listed or missing in the attribution screen.\nIt might also fail to identify licenses if the dependencies do not define it properly in their\npom.xml file.\n\nCareful optimisation and review of all licenses is recommended to really include all required\ndependencies. The use of the gradle commands like `findLibraries` can help doing this.\n\nIt is also important that native sub dependencies can *not* be resolved automatically as they are\nnot included via gradle.\nAdditional dependencies can be provided via the plugins API to extend and provide any additional\ndetails.\n\n# Credits\n\nStarting from v12.1.0 some parts of the plugin were refactored to use different APIs to retrieve dependencies.\nSome of these refactored components were heavily inspired by the amazing https:\u002F\u002Fgithub.com\u002Fcashapp\u002Flicensee\u002Ftree\u002F1.13.0 project.\n\n# Developed By\n\n- Mike Penz\n    - [mikepenz.dev](https:\u002F\u002Fmikepenz.dev) - [blog.mikepenz.dev](https:\u002F\u002Fblog.mikepenz.dev) - \u003Cmikepenz@gmail.com>\n    - [paypal.me\u002Fmikepenz](http:\u002F\u002Fpaypal.me\u002Fmikepenz)\n    - [Automatic changelog generation action](https:\u002F\u002Fgithub.com\u002Fmarketplace\u002Factions\u002Frelease-changelog-builder)\n\n# License\n\n    Copyright 2024 Mike Penz\n\n    Licensed under the Apache License, Version 2.0 (the \"License\");\n    you may not use this file except in compliance with the License.\n    You may obtain a copy of the License at\n\n       http:\u002F\u002Fwww.apache.org\u002Flicenses\u002FLICENSE-2.0\n\n    Unless required by applicable law or agreed to in writing, software\n    distributed under the License is distributed on an \"AS IS\" BASIS,\n    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n    See the License for the specific language governing permissions and\n    limitations under the License.\n","AboutLibraries 是一个自动收集 Gradle 项目（包括 Kotlin MultiPlatform）依赖和许可证信息，并提供易于集成的 UI 组件的库，适用于 Android 和 Compose Multiplatform 环境。其核心功能是在编译时收集依赖详情及许可证信息，并通过简单的 API 在应用中展示这些信息，无运行时开销且支持强缓存。该库还包含一个 Gradle 插件，用于生成依赖\u002F许可证元数据、合规报告等。适用于需要在应用内展示第三方库信息及其许可证的场景，尤其是对于使用 Kotlin Multiplatform 进行跨平台开发的项目。","2026-06-11 03:11:40","top_language"]