Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nebula-plugins/gradle-info-plugin
Plugin to gather information about the environment
https://github.com/nebula-plugins/gradle-info-plugin
Last synced: 1 day ago
JSON representation
Plugin to gather information about the environment
- Host: GitHub
- URL: https://github.com/nebula-plugins/gradle-info-plugin
- Owner: nebula-plugins
- License: apache-2.0
- Created: 2014-02-03T19:13:38.000Z (almost 11 years ago)
- Default Branch: main
- Last Pushed: 2024-12-09T17:55:56.000Z (about 1 month ago)
- Last Synced: 2025-01-05T05:08:26.930Z (15 days ago)
- Language: Groovy
- Size: 1.49 MB
- Stars: 49
- Watchers: 19
- Forks: 20
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
Gradle Info Plugin
=====================
![Support Status](https://img.shields.io/badge/nebula-active-green.svg)
[![Gradle Plugin Portal](https://img.shields.io/maven-metadata/v/https/plugins.gradle.org/m2/com.netflix.nebula/gradle-info-plugin/maven-metadata.xml.svg?label=gradlePluginPortal)](https://plugins.gradle.org/plugin/com.netflix.nebula.info)
[![Maven Central](https://img.shields.io/maven-central/v/com.netflix.nebula/gradle-info-plugin)](https://maven-badges.herokuapp.com/maven-central/com.netflix.nebula/gradle-info-plugin)
![Build](https://github.com/nebula-plugins/gradle-info-plugin/actions/workflows/nebula.yml/badge.svg)
[![Apache 2.0](https://img.shields.io/github/license/nebula-plugins/gradle-info-plugin.svg)](http://www.apache.org/licenses/LICENSE-2.0)Noninvasively collect information about the environment, and make information available to other plugins in a statically typed way. When possible lazily calculate info.
The module is made of three types of plugins.
* Collecting plugins, e.g. scm-info and ci-info. Both of those examples use specific implementations to detect the current
environment and report values to the broker.
* Reporting plugins, e.g. Jar manifests, a generated file. These have specific formatting and outputting requirements, so they pull
from the Broker. These will force values into
* A Broker plugin, to collect values from Collecting plugins and make them available to reporting pluginsBoth the Collectors and Reporters know about the broker.
info Plugin
--------------
```
apply plugin: 'com.netflix.nebula.info'
```*Uber plugin that applies all other plugins. Since each one is relatively safe to run, this is the recommended plugin to
apply.*info-broker Plugin (Broker)
---------------
```
apply plugin: 'com.netflix.nebula.info-broker'
```This would leave an empty broker around for other plugins to play with.
info-jar Plugin (Reporter)
---------------
```
apply plugin: 'com.netflix.nebula.info-jar'// optionally configure MANIFEST.MF entries
infoBroker {
excludedManifestProperties = ['Build-Date', 'Built-OS']
// or, but not both!
includedManifestProperties = ['Build-Date']
}```
Pumps all values from the broker into the manifest of all jar's being built.
info-props Plugin (Reporter)
---------------
```
apply plugin: 'com.netflix.nebula.info-props'
```Creates a property files with broker's values, defaults to "manifest/${baseConvention.archivesBaseName}.properties". Uses
InfoPropertiesFile task to create file.info-jar-props Plugin (Reporter)
---------------
```
apply plugin: 'com.netflix.nebula.info-jar-props'
```Leverages info-props to create a file, which this plugin then puts into the META-INF of all jars.
info-basic Plugin (Collector)
--------------```
apply plugin: 'nebula.info-basic'
```Provides some basic values relavant to the Gradle build, e.g. build status.
info-java Plugin (Collector)
--------------```
apply plugin: 'com.netflix.nebula.info-java'
```Reports on the version of Java being used, and compatibility version if the Java plugin is being used.
info-ci Plugin (Collector)
--------------```
apply plugin: 'com.netflix.nebula.info-ci'
```Detects the current Continuous Integration environment and reports upon Job Name and Build Number.
Currently supports CircleCI, Cirrus CI, Drone, GitLab CI, Travis CI, and Jenkins.info-dependencies Plugin (Collector)
--------------
```
apply plugin: 'com.netflix.nebula.info-dependencies'
```Reports on selected binary module versions (including transitives) of configurations that are resolved.
info-scm Plugin (Collector)
--------------
```
apply plugin: 'com.netflix.nebula.info-scm'
```Detects the current source control being used and reports upon the repository and where in the source the project is.
Git and Perforce are currently supported. Since real java libraries are used to determine these values but we don't want
to pollute too many people with Perforce, all the plugin implementations are optional. You'll have to add a dependency to
your specific SCM implementation. Technically, these are not optional right now, but they will be in the future.```
buildscript {
repositories { mavenCentral() }
dependencies { classpath 'com.netflix.nebula:gradle-info-plugin:3.3.+' }dependencies { classpath 'com.perforce:p4java:2012.3.551082' }
// or
dependencies { classpath 'org.eclipse.jgit:org.eclipse.jgit:3.2.0.201312181205-r' }
}
```info-owners (Collector)
--------------
```
apply plugin: 'com.netflix.nebula.info-owners'
```Collects "owners" and "notify" users and inject them as 'Module-Owner' and 'Module-Email', respectively. The values come
from the gradle-contacts plugin.```
apply plugin: 'contacts'
contacts {
'[email protected]' {
moniker 'Mickey Mouse'
role 'owner'
}
}
```The above will make sure the manifest contains a Module-Owner of [email protected].