All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.mooltiverse.oss.nyx.gradle.NyxExtension Maven / Gradle / Ivy

/*
 * Copyright 2020 Mooltiverse
 *
 * 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.
 */
package com.mooltiverse.oss.nyx.gradle;

import java.io.File;
import javax.inject.Inject;

import org.gradle.api.Action;
import org.gradle.api.NamedDomainObjectContainer;
import org.gradle.api.Project;
import org.gradle.api.initialization.Settings;
import org.gradle.api.model.ObjectFactory;
import org.gradle.api.provider.ListProperty;
import org.gradle.api.provider.MapProperty;
import org.gradle.api.provider.Property;
import org.gradle.api.provider.Provider;

import com.mooltiverse.oss.nyx.entities.Defaults;

/**
 * The plugin configuration object. This object is responsible for reading the {@code nyx {...} } configuration block that users
 * define within the {@code build.gradle} script.
 * 
* See Modeling DSL-like APIs * for more o developing extension. *
* See Developing Custom Gradle Types, * Developing Custom Gradle Plugins, * Implementing Gradle plugins and * Lazy Configuration * for an introduction on custom Gradle types development. *

* NOTES ON NESTED OBJECTS:
* In order to support DSL (the curly braces syntax) for nested objects we also need to support one additional method for each nested object * to accept and configure the closure. Take the {@code commitMessageConventions} for example. According to the API docs, defining the * field and the getter method as as:

*
 *      private CommitMessageConventions commitMessageConventions = getObjectfactory().newInstance(CommitMessageConventions.class);
 * 
 *      public CommitMessageConventions getCommitMessageConventions() {
 *          return commitMessageConventions;
 *          }
 * 
* should be enough but it's not, in fact at runtime, when using the curly braces syntax to define that property like:

*
 * nyx {
 *   commitMessageConventions {
 *      enabled = ['conventionalCommits']
 *   }
 * }
 * 
* throws an exception like:

*
 * org.gradle.api.GradleScriptException: A problem occurred evaluating root project...
 *      ...
 *      Caused by: groovy.lang.MissingMethodException: No signature of method: build_araz4us455w31lfualzy83h1f.nyx() is applicable for argument types: (build_araz4us455w31lfualzy83h1f$_run_closure1) values: [build_araz4us455w31lfualzy83h1f$_run_closure1@22b6a7c8]
 *      Possible solutions: any(), any(groovy.lang.Closure), run(), run(), sync(org.gradle.api.Action), uri(java.lang.Object)
 *      ...
 * 
* So thanks to posts like this * (which points to this example here), * this and * this * it turns out there must be another method to accept the closure. I don't know Groovy so I'm not sure what it's needed for but the * additional method can be in one of the two following variants (still using the {@code commitMessageConventions} example):

*
 *      public void commitMessageConventions(groovy.lang.Closure closure) {
 *          closure.setResolveStrategy(groovy.lang.Closure.DELEGATE_FIRST);
 *          closure.setDelegate(commitMessageConventions);
 *          closure.call();
 *      }
 * 
* or:
*
 *      public void commitMessageConventions(org.gradle.api.Action<? super CommitMessageConventions> configuration) {
 *          configuration.execute(commitMessageConventions);
 *      }
 * 
* I opted for the second one, as it's a little more comprehensible, although I don't know exactly what happens under the hood. * * @see org.gradle.api.plugins.ExtensionAware * @see org.gradle.api.plugins.ExtensionContainer */ public abstract class NyxExtension { /** * The name of the extension object. This is the name of the configuration block inside Gradle scripts. */ public static final String NAME = "nyx"; /** * The 'bump' property. */ private final Property bump = getObjectfactory().property(String.class); /** * The nested 'changelog' block. */ private final ChangelogConfiguration changelog = getObjectfactory().newInstance(ChangelogConfiguration.class); /** * The nested 'commitMessageConventions' block. */ private final CommitMessageConventions commitMessageConventions = getObjectfactory().newInstance(CommitMessageConventions.class); /** * The 'configurationFile' property. */ private final Property configurationFile = getObjectfactory().property(String.class); /** * The 'directory' property. * Default is taken from the Gradle project directory but the method to retrieve that is * based on where this object is applied (see the {@link #create(Project)} and * {@link #create(Settings)} methods). * * This property uses the {@link Property#convention(Provider)} to define the default value so * when users are good with the default value they don't need to define it in the build script. * * @see #create(Project) * @see #create(Settings) */ private final Property directory = getObjectfactory().property(File.class); /** * The 'dryRun' property. */ private final Property dryRun = getObjectfactory().property(Boolean.class); /** * The nested 'git' block. */ private final GitConfiguration git = getObjectfactory().newInstance(GitConfiguration.class); /** * The 'initialVersion' property. */ private final Property initialVersion = getObjectfactory().property(String.class); /** * The 'preset' property. */ private final Property preset = getObjectfactory().property(String.class); /** * The nested 'releaseAssets' block. * * @see AssetConfiguration */ private NamedDomainObjectContainer releaseAssets = getObjectfactory().domainObjectContainer(AssetConfiguration.class); /** * The 'releaseLenient' property. */ private final Property releaseLenient = getObjectfactory().property(Boolean.class); /** * The 'releasePrefix' property. */ private final Property releasePrefix = getObjectfactory().property(String.class); /** * The nested 'releaseTypes' block. */ private final ReleaseTypes releaseTypes = getObjectfactory().newInstance(ReleaseTypes.class); /** * The 'resume' property. */ private final Property resume = getObjectfactory().property(Boolean.class); /** * The 'scheme' property. */ private final Property scheme = getObjectfactory().property(String.class); /** * The nested 'services' block. * * @see ServiceConfiguration */ private NamedDomainObjectContainer services = getObjectfactory().domainObjectContainer(ServiceConfiguration.class); /** * The 'sharedConfigurationFile' property. */ private final Property sharedConfigurationFile = getObjectfactory().property(String.class); /** * The 'summary' property. */ private final Property summary = getObjectfactory().property(Boolean.class); /** * The 'summaryFile' property. */ private final Property summaryFile = getObjectfactory().property(String.class); /** * The 'stateFile' property. */ private final Property stateFile = getObjectfactory().property(String.class); /** * The nested 'substitutions' block. */ private final Substitutions substitutions = getObjectfactory().newInstance(Substitutions.class); /** * The 'verbosity' property. * * Please note that the verbosity option is actually ignored in this plugin implementation and the backing Nyx implementation * as it's controlled by Gradle. */ private final Property verbosity = getObjectfactory().property(String.class); /** * Default constructor. */ public NyxExtension() { super(); } /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Creates the extension into the given project. * * @param project the project to create the extension into * * @return the extension instance, within the given project */ public static NyxExtension create(Project project) { NyxExtension extension = project.getExtensions().create(NyxExtension.NAME, NyxExtension.class); extension.directory.convention(project.getLayout().getProjectDirectory().getAsFile()); return extension; } /** * Creates the extension into the given settings. * * @param settings the settings to create the extension into * * @return the extension instance, within the given settings */ public static NyxExtension create(Settings settings) { NyxExtension extension = settings.getExtensions().create(NyxExtension.NAME, NyxExtension.class); extension.directory.convention(settings.getRootDir()); return extension; } /** * Returns the name of the version identifier to bump. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the name of the version identifier to bump */ public Property getBump() { return bump; } /** * Returns the object mapping the {@code changelog} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code changelog} block */ public ChangelogConfiguration getChangelog() { return changelog; } /** * Accepts the DSL configuration for the {@code changelog} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code changelog} block */ public void changelog(Action configurationAction) { configurationAction.execute(changelog); } /** * Returns the object mapping the {@code commitMessageConventions} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code commitMessageConventions} block */ public CommitMessageConventions getCommitMessageConventions() { return commitMessageConventions; } /** * Accepts the DSL configuration for the {@code commitMessageConventions} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code commitMessageConventions} block */ public void commitMessageConventions(Action configurationAction) { configurationAction.execute(commitMessageConventions); } /** * Returns the custom configuration file to use. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the custom configuration file to use * * @see Defaults#SHARED_CONFIGURATION_FILE */ public Property getConfigurationFile() { return configurationFile; } /** * Returns the directory to use as the base repository location. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the directory to use as the base repository location */ public Property getDirectory() { return directory; } /** * Returns the flag that, when {@code true}, prevents Nyx from applying any change to the repository or any * other resource. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the flag that, when {@code true}, prevents Nyx from applying any change to the repository or any * other resource * * @see Defaults#DRY_RUN */ public Property getDryRun() { return dryRun; } /** * Returns the object mapping the {@code git} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code git} block */ public GitConfiguration getGit() { return git; } /** * Accepts the DSL configuration for the {@code git} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code git} block */ public void git(Action configurationAction) { configurationAction.execute(git); } /** * Returns the initial version to use when no past version can be inferred from the commit history. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the flag that, when {@code true}, prevents Nyx from applying any change to the repository or any * other resource * * @see Defaults#DRY_RUN */ public Property getInitialVersion() { return initialVersion; } /** * Returns the selected preset configuration name. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the selected preset configuration name. * * @see Defaults#PRESET */ public Property getPreset() { return preset; } /** * Returns the object mapping the {@code releaseAssets} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code releaseAssets} block */ public NamedDomainObjectContainer getReleaseAssets() { return releaseAssets; } /** * Accepts the DSL configuration for the {@code releaseAssets} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code releaseAssets} block */ public void releaseAssets(Action> configurationAction) { configurationAction.execute(releaseAssets); } /** * Returns the flag that, when {@code true}, lets Nyx interpret release names with whatever prefix. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the flag that, when {@code true}, lets Nyx interpret release names with whatever prefix * * @see Defaults#RELEASE_LENIENT */ public Property getReleaseLenient() { return releaseLenient; } /** * Returns the prefix used to generate release names. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the prefix used to generate release names * * @see Defaults#RELEASE_PREFIX */ public Property getReleasePrefix() { return releasePrefix; } /** * Returns the object mapping the {@code releaseTypes} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code releaseTypes} block */ public ReleaseTypes getReleaseTypes() { return releaseTypes; } /** * Accepts the DSL configuration for the {@code releaseTypes} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code releaseTypes} block */ public void releaseTypes(Action configurationAction) { configurationAction.execute(releaseTypes); } /** * Returns the flag that, when {@code true}, loads a previously saved state file (if any) to resume execution * from there. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the flag that, when {@code true}, prevents Nyx from applying any change to the repository or any * other resource * * @see Defaults#DRY_RUN */ public Property getResume() { return resume; } /** * Returns the versioning scheme to use. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the versioning scheme to use * * @see Defaults#SCHEME */ public Property getScheme() { return scheme; } /** * Returns the object mapping the {@code services} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code services} block */ public NamedDomainObjectContainer getServices() { return services; } /** * Accepts the DSL configuration for the {@code services} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code services} block */ public void services(Action> configurationAction) { configurationAction.execute(services); } /** * Returns the custom shared configuration file to use. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the custom shared configuration file to use * * @see Defaults#SHARED_CONFIGURATION_FILE */ public Property getSharedConfigurationFile() { return sharedConfigurationFile; } /** * Returns the flag that, when {@code true}, prints a state summary to the console. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the flag that, when {@code true}, prevents Nyx from applying any change to the repository or any * other resource * * @see Defaults#DRY_RUN */ public Property getSummary() { return summary; } /** * Returns the optional path where to save the summary file. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the directory to use as the base repository location */ public Property getSummaryFile() { return summaryFile; } /** * Returns the optional path where to save the state file. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the directory to use as the base repository location */ public Property getStateFile() { return stateFile; } /** * Returns the object mapping the {@code substitutions} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code substitutions} block */ public Substitutions getSubstitutions() { return substitutions; } /** * Accepts the DSL configuration for the {@code substitutions} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code substitutions} block */ public void substitutions(Action configurationAction) { configurationAction.execute(substitutions); } /** * Returns the logging verbosity. * * Please note that the verbosity option is actually ignored in this plugin implementation and the backing Nyx implementation * as it's controlled by Gradle. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the logging verbosity */ public Property getVerbosity() { return verbosity; } /** * The class to model the 'changelog' block within the extension. */ public abstract static class ChangelogConfiguration { /** * The flag instructing if and when to append contents to the existing changelog file. */ private final Property append = getObjectfactory().property(String.class); /** * The path to the destination file. */ private final Property path = getObjectfactory().property(String.class); /** * The path to the optional template file. */ private final Property template = getObjectfactory().property(String.class); /** * The nested 'sections' block. */ private final MapProperty sections = getObjectfactory().mapProperty(String.class, String.class); /** * The nested 'substitutions' block. */ private final MapProperty substitutions = getObjectfactory().mapProperty(String.class, String.class); /** * Default constructor. */ public ChangelogConfiguration() { super(); } /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Returns the flag instructing if and when to append contents to the existing changelog file. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the flag instructing if and when to append contents to the existing changelog file. */ public Property getAppend() { return append; } /** * Returns the path to the destination file. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the path to the destination file. */ public Property getPath() { return path; } /** * Returns the path to the optional template file. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the path to the optional template file. */ public Property getTemplate() { return template; } /** * Returns the map of changelog sections. * * @return the map of changelog sections. */ public MapProperty getSections() { return sections; } /** * Accepts the DSL configuration for the {@code sections} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code sections} block */ public void sections(Action> configurationAction) { configurationAction.execute(sections); } /** * Returns the map of changelog substitutions. * * @return the map of changelog substitutions. */ public MapProperty getSubstitutions() { return substitutions; } /** * Accepts the DSL configuration for the {@code substitutions} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code substitutions} block */ public void substitutions(Action> configurationAction) { configurationAction.execute(substitutions); } } /** * The class to model the 'commitMessageConventions' block within the extension. */ public abstract static class CommitMessageConventions { /** * The list of enabled convention names. */ private final ListProperty enabled = getObjectfactory().listProperty(String.class); /** * The nested 'items' block. * * @see CommitMessageConvention */ private NamedDomainObjectContainer items = getObjectfactory().domainObjectContainer(CommitMessageConvention.class); /** * Default constructor. */ public CommitMessageConventions() { super(); } /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Returns list of enabled convention names. * * @return list of enabled convention names. */ public ListProperty getEnabled() { return enabled; } /** * Returns the map of commit message convention items. * * @return the map of commit message convention items. */ public NamedDomainObjectContainer getItems() { return items; } /** * Accepts the DSL configuration for the {@code items} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code items} block */ public void items(Action> configurationAction) { configurationAction.execute(items); } /** * The class to model a single 'commitMessageConventions' item within the extension. */ public abstract static class CommitMessageConvention { /** * The convention name. */ private final String name; /** * The convention regular expression property. */ private final Property expression = getObjectfactory().property(String.class); /** * The nested 'bumpExpressions' block. * * @see CommitMessageConvention */ private final MapProperty bumpExpressions = getObjectfactory().mapProperty(String.class, String.class); /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Constructor. * * This constructor is required as per the {@link NamedDomainObjectContainer} specification. * * @param name the convention name */ public CommitMessageConvention(String name) { super(); this.name = name; } /** * Returns the name read-only mandatory property. * * @return the name read-only mandatory property. */ public String getName() { return name; } /** * Returns the regular expression to infer fields from a commit message. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the regular expression to infer fields from a commit message */ public Property getExpression() { return expression; } /** * Returns the map of bump expression items. * * @return the map of bump expression items. */ public MapProperty getBumpExpressions() { return bumpExpressions; } /** * Accepts the DSL configuration for the {@code bumpExpressions} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code bumpExpressions} block */ public void bumpExpressions(Action> configurationAction) { configurationAction.execute(bumpExpressions); } } } /** * The class to model the 'git' block within the extension. */ public abstract static class GitConfiguration { /** * The nested 'remotes' block. * * @see GitRemoteConfiguration */ private NamedDomainObjectContainer remotes = getObjectfactory().domainObjectContainer(GitRemoteConfiguration.class); /** * Default constructor. */ public GitConfiguration() { super(); } /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Returns the map of remotes. * * @return the map of remotes. */ public NamedDomainObjectContainer getRemotes() { return remotes; } /** * Accepts the DSL configuration for the {@code remotes} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code items} block */ public void remotes(Action> configurationAction) { configurationAction.execute(remotes); } /** * The class to model a single 'remotes' item within the extension. */ public abstract static class GitRemoteConfiguration { /** * The remote name. */ private final String name; /** * The remote authentication method property. */ private final Property authenticationMethod = getObjectfactory().property(String.class); /** * The remote password property. */ private final Property password = getObjectfactory().property(String.class); /** * The remote user property. */ private final Property user = getObjectfactory().property(String.class); /** * The remote private key property. */ private final Property privateKey = getObjectfactory().property(String.class); /** * The remote passphrase for the private key property. */ private final Property passphrase = getObjectfactory().property(String.class); /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Constructor. * * This constructor is required as per the {@link NamedDomainObjectContainer} specification. * * @param name the remote name */ public GitRemoteConfiguration(String name) { super(); this.name = name; } /** * Returns the name read-only mandatory property. * * @return the name read-only mandatory property. */ public String getName() { return name; } /** * Returns the remote authentication method. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the remote authentication method */ public Property getAuthenticationMethod() { return authenticationMethod; } /** * Returns the remote password. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the remote password */ public Property getPassword() { return password; } /** * Returns the remote user. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the remote user */ public Property getUser() { return user; } /** * Returns the remote private key. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the remote private key */ public Property getPrivateKey() { return privateKey; } /** * Returns the remote passphrase for the private key. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the remote passphrase for the private key */ public Property getPassphrase() { return passphrase; } } } /** * The class to model a single 'releaseAssets' item within the extension. */ public abstract static class AssetConfiguration { /** * The asset name. */ private final String name; /** * The asset file name property. */ private final Property fileName = getObjectfactory().property(String.class); /** * The asset (short) description (or label) property. */ private final Property description = getObjectfactory().property(String.class); /** * The asset path property (local file or URL). */ private final Property path = getObjectfactory().property(String.class); /** * The asset MIME type property. */ private final Property type = getObjectfactory().property(String.class); /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Constructor. * * This constructor is required as per the {@link NamedDomainObjectContainer} specification. * * @param name the asset name (the map key) */ public AssetConfiguration(String name) { super(); this.name = name; } /** * Returns the asset name read-only mandatory property. * * @return the asset name read-only mandatory property. */ public String getName() { return name; } /** * Returns the asset file name. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the asset name (usually the file name) */ public Property getFileName() { return fileName; } /** * Returns the asset (short) description (or label) property. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the asset (short) description (or label) */ public Property getDescription() { return description; } /** * Returns the asset path (local file or URL). * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the asset path (local file or URL) */ public Property getPath() { return path; } /** * Returns the asset MIME type. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the asset MIME type */ public Property getType() { return type; } } /** * The class to model the 'releaseTypes' block within the extension. */ public abstract static class ReleaseTypes { /** * The list of enabled release type names. */ private final ListProperty enabled = getObjectfactory().listProperty(String.class); /** * The list of publication service names. */ private final ListProperty publicationServices = getObjectfactory().listProperty(String.class); /** * The list of remote repository names. */ private final ListProperty remoteRepositories = getObjectfactory().listProperty(String.class); /** * The nested 'items' block. * * @see ReleaseType */ private NamedDomainObjectContainer items = getObjectfactory().domainObjectContainer(ReleaseType.class); /** * Default constructor. */ public ReleaseTypes() { super(); } /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Returns list of enabled convention names. * * @return list of enabled convention names. */ public ListProperty getEnabled() { return enabled; } /** * Returns list of publication service names. * * @return list of publication service names. */ public ListProperty getPublicationServices() { return publicationServices; } /** * Returns list of remote repository names. * * @return list of remote repository names. */ public ListProperty getRemoteRepositories() { return remoteRepositories; } /** * Returns the map of release type items. * * @return the map of release type items. */ public NamedDomainObjectContainer getItems() { return items; } /** * Accepts the DSL configuration for the {@code items} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code items} block */ public void items(Action> configurationAction) { configurationAction.execute(items); } /** * The class to model a single 'releaseTypes' item within the extension. */ public abstract static class ReleaseType { /** * The release type name. */ private final String name; /** * The list of enabled assets for the release type. */ // We need to let Gradle parse this as a string rather than a list of strings. // As documented at https://github.com/mooltiverse/nyx/issues/110, ListProperty.isPresent() never returns 'false', even when the // property hasn't been defined by the user, so we are unable to distinguish when it was defined as empty or not defined at all. // Within Nyx we have different semantics for the two cases o we need to read it as a simple string of comma separated items and // then (in the ConfigurationLayer class) split them to a list, if the string property was defined. private final Property assets = getObjectfactory().property(String.class); /** * The flag indicating whether or not the 'collapsed' versioning (pre-release style) must be used. */ private final Property collapseVersions = getObjectfactory().property(Boolean.class); /** * The optional qualifier or the template to render the qualifier to use for the pre-release identifier when versions are collapsed. */ private final Property collapsedVersionQualifier = getObjectfactory().property(String.class); /** * The optional template to render as a regular expression used for the release description. */ private final Property description = getObjectfactory().property(String.class); /** * The optional template to render as a regular expression used to match tags from the commit history. */ private final Property filterTags = getObjectfactory().property(String.class); /** * The optional flag or the template to render indicating whether or not a new commit must be generated in case new artifacts are generated. */ private final Property gitCommit = getObjectfactory().property(String.class); /** * The optional string or the template to render to use as the commit message if a commit has to be made. */ private final Property gitCommitMessage = getObjectfactory().property(String.class); /** * The optional flag or the template to render indicating whether or not a new commit must be generated and pushed in case new artifacts are generated. */ private final Property gitPush = getObjectfactory().property(String.class); /** * The optional flag or the template to enable/disable the Git push operation. */ private final Property gitPushForce = getObjectfactory().property(String.class); /** * The optional flag or the template to render indicating whether or not a new tag must be generated. */ private final Property gitTag = getObjectfactory().property(String.class); /** * The optional flag or the template to enable/disable the Git tag operation. */ private final Property gitTagForce = getObjectfactory().property(String.class); /** * The optional string or the template to render to use as the tag message if a tag has to be made. */ private final Property gitTagMessage = getObjectfactory().property(String.class); /** * The list of templates to use as tag names when tagging a commit. */ private final ListProperty gitTagNames = getObjectfactory().listProperty(String.class); /** * The nested 'identifiers' block. */ // TODO: remove this member if and when https://github.com/mooltiverse/nyx/issues/77 is solved private NamedDomainObjectContainer identifiers = getObjectfactory().domainObjectContainer(Identifier.class); /** * The nested 'identifiers' block. */ // TODO: uncomment this member if and when https://github.com/mooltiverse/nyx/issues/77 is solved //private final ListProperty identifiers = getObjectfactory().listProperty(Identifier.class); /** * The optional template to render as a regular expression used to match branch names. */ private final Property matchBranches = getObjectfactory().property(String.class); /** * The identifier of a specific workspace status to be matched. */ private final Property matchWorkspaceStatus = getObjectfactory().property(String.class); /** * The optional flag or the template to render indicating whether or not releases must be published. */ private final Property publish = getObjectfactory().property(String.class); /** * The the optional template to set the draft flag of releases published to remote services. */ private final Property publishDraft = getObjectfactory().property(String.class); /** * The optional template to set the pre-release flag of releases published to remote services. */ private final Property publishPreRelease = getObjectfactory().property(String.class); /** * The optional template to set the name of releases published to remote services. */ private final Property releaseName = getObjectfactory().property(String.class); /** * The optional template to render as a regular expression used to constrain versions issued by this release type. */ private final Property versionRange = getObjectfactory().property(String.class); /** * The optional flag telling if the version range must be inferred from the branch name. */ private final Property versionRangeFromBranchName = getObjectfactory().property(Boolean.class); /** * The nested 'matchEnvironmentVariables' block. */ private final MapProperty matchEnvironmentVariables = getObjectfactory().mapProperty(String.class, String.class); /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Constructor. * * This constructor is required as per the {@link NamedDomainObjectContainer} specification. * * @param name the release type name */ public ReleaseType(String name) { super(); this.name = name; } /** * Returns the name read-only mandatory property. * * @return the name read-only mandatory property. */ public String getName() { return name; } /** * Returns a string with the comma separatedlist of selected asset names to publish with the release. * When {@code null} all assets configured globally (if any) must be published, otherwise only the assets * in this list must be published for this release type. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the list of selected asset names to publish with the release. */ public Property getAssets() { return assets; } /** * Returns the flag indicating whether or not the 'collapsed' versioning (pre-release style) must be used. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the flag indicating whether or not the 'collapsed' versioning (pre-release style) must be used. */ public Property getCollapseVersions() { return collapseVersions; } /** * Returns the optional qualifier or the template to render the qualifier to use for the pre-release * identifier when versions are collapsed. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional qualifier or the template to render the qualifier to use for the pre-release * identifier when versions are collapsed */ public Property getCollapsedVersionQualifier() { return collapsedVersionQualifier; } /** * Returns the optional flag or the template to render indicating the release description. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag or the template to render indicating the release description. */ public Property getDescription() { return description; } /** * Returns the optional template to render as a regular expression used to match tags * from the commit history. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional template to render as a regular expression used to match tags * from the commit history. */ public Property getFilterTags() { return filterTags; } /** * Returns the optional flag or the template to render indicating whether or not a new commit must be generated in case new artifacts are generated. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag or the template to render indicating whether or not a new commit must be generated in case new artifacts are generated. */ public Property getGitCommit() { return gitCommit; } /** * Returns the optional string or the template to render to use as the commit message if a commit has to be made. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional string or the template to render to use as the commit message if a commit has to be made. */ public Property getGitCommitMessage() { return gitCommitMessage; } /** * Returns the optional flag or the template to render indicating whether or not a new commit must be generated and pushed in case new artifacts are generated. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag or the template to render indicating whether or not a new commit must be generated and pushed in case new artifacts are generated. */ public Property getGitPush() { return gitPush; } /** * Returns optional flag or the template to enable/disable the Git push operation. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag or the template to enable/disable the Git push operation. */ public Property getGitPushForce() { return gitPushForce; } /** * Returns the optional flag or the template to render indicating whether or not a new tag must be generated. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag or the template to render indicating whether or not a new tag must be generated. */ public Property getGitTag() { return gitTag; } /** * Returns optional flag or the template to enable/disable the Git tag operation. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag or the template to enable/disable the Git tag operation. */ public Property getGitTagForce() { return gitTagForce; } /** * Returns the optional string or the template to render to use as the tag message if a tag has to be made. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional string or the template to render to use as the tag message if a tag has to be made. */ public Property getGitTagMessage() { return gitTagMessage; } /** * Returns the list of templates to use as tag names when tagging a commit. * * @return the list of templates to use as tag names when tagging a commit. */ public ListProperty getGitTagNames() { return gitTagNames; } /** * Returns the map of identifier items. * * @return the map of identifier items. */ public NamedDomainObjectContainer getIdentifiers() { // TODO: remove this method if and when https://github.com/mooltiverse/nyx/issues/77 is solved return identifiers; } /** * Accepts the DSL configuration for the {@code identifiers} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code identifiers} block */ public void identifiers(Action> configurationAction) { // TODO: remove this method if and when https://github.com/mooltiverse/nyx/issues/77 is solved configurationAction.execute(identifiers); } /** * Returns the object mapping the {@code identifiers} block. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the object mapping the {@code identifiers} block */ /*public ListProperty getIdentifiers() { // TODO: uncomment this method if and when https://github.com/mooltiverse/nyx/issues/77 is solved return identifiers; }*/ /** * Accepts the DSL configuration for the {@code identifiers} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configuration the configuration object for the {@code identifiers} block */ /*public void identifiers(Action> configurationAction) { // TODO: uncomment this method if and when https://github.com/mooltiverse/nyx/issues/77 is solved configurationAction.execute(identifiers); }*/ /** * Returns the optional template to render as a regular expression used to match branch names. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional template to render as a regular expression used to match branch names. */ public Property getMatchBranches() { return matchBranches; } /** * Returns the map of match environment variables names and regular expressions items. * * @return the map of match environment variables names and regular expressions items. */ public MapProperty getMatchEnvironmentVariables() { return matchEnvironmentVariables; } /** * Accepts the DSL configuration for the {@code matchEnvironmentVariables} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code matchEnvironmentVariables} block */ public void matchEnvironmentVariables(Action> configurationAction) { configurationAction.execute(matchEnvironmentVariables); } /** * Returns the identifier of a specific workspace status to be matched. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the identifier of a specific workspace status to be matched. */ public Property getMatchWorkspaceStatus() { return matchWorkspaceStatus; } /** * Returns the optional flag or the template to render indicating whether or not releases must be published. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag or the template to render indicating whether or not releases must be published. */ public Property getPublish() { return publish; } /** * Returns the optional template to set the draft flag of releases published to remote services. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional template to set the draft flag of releases published to remote services. */ public Property getPublishDraft() { return publishDraft; } /** * Returns the optional template to set the pre-release flag of releases published to remote services. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional template to set the pre-release flag of releases published to remote services. */ public Property getPublishPreRelease() { return publishPreRelease; } /** * Returns the optional template to set the name of releases published to remote services. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional template to set the name of releases published to remote services. */ public Property getReleaseName() { return releaseName; } /** * Returns the optional template to render as a regular expression used to constrain versions issued by this release type. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional template to render as a regular expression used to constrain versions issued by this release type. */ public Property getVersionRange() { return versionRange; } /** * Returns the optional flag telling if the version range must be inferred from the branch name. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the optional flag telling if the version range must be inferred from the branch name. */ public Property getVersionRangeFromBranchName() { return versionRangeFromBranchName; } /** * The class to model a single 'identifiers' item within the extension. */ public abstract static class Identifier { /** * The identifier name. */ // TODO: remove this member if and when https://github.com/mooltiverse/nyx/issues/77 is solved private final String name; /** * The identifier position. */ private final Property position = getObjectfactory().property(String.class); /** * The identifier qualifier. */ private final Property qualifier = getObjectfactory().property(String.class); /** * The identifier value. */ private final Property value = getObjectfactory().property(String.class); /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Constructor. * * This constructor is required as per the {@link NamedDomainObjectContainer} specification. * * @param name the identifier name */ public Identifier(String name) { super(); // TODO: remove this member if and when https://github.com/mooltiverse/nyx/issues/77 is solved this.name = name; } /** * Returns the name read-only mandatory property. * * @return the name read-only mandatory property. */ public String getName() { return name; } /** * Returns the identifier qualifier. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the identifier qualifier. */ public Property getPosition() { return position; } /** * Returns the identifier qualifier. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the identifier qualifier. */ public Property getQualifier() { return qualifier; } /** * Returns the identifier value. * When this is set by the user it overrides the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the identifier value. */ public Property getValue() { return value; } } } } /** * The class to model a single 'services' item within the extension. */ public abstract static class ServiceConfiguration { /** * The service name. */ private final String name; /** * The service type property. */ private final Property type = getObjectfactory().property(String.class); /** * The nested 'options' block. */ private final MapProperty options = getObjectfactory().mapProperty(String.class, String.class); /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Constructor. * * This constructor is required as per the {@link NamedDomainObjectContainer} specification. * * @param name the service name */ public ServiceConfiguration(String name) { super(); this.name = name; } /** * Returns the name read-only mandatory property. * * @return the name read-only mandatory property. */ public String getName() { return name; } /** * Returns the service type. When this is set by the user it overrides * the inference performed by Nyx. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the service type */ public Property getType() { return type; } /** * Returns the map of service options. * * @return the map of service options. */ public MapProperty getOptions() { return options; } /** * Accepts the DSL configuration for the {@code options} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code options} block */ public void options(Action> configurationAction) { configurationAction.execute(options); } } /** * The class to model the 'substitutions' block within the extension. */ public abstract static class Substitutions { /** * The list of enabled substitution names. */ private final ListProperty enabled = getObjectfactory().listProperty(String.class); /** * The nested 'items' block. * * @see Substitution */ private NamedDomainObjectContainer items = getObjectfactory().domainObjectContainer(Substitution.class); /** * Default constructor. */ public Substitutions() { super(); } /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Returns list of enabled substitution names. * * @return list of enabled substitution names. */ public ListProperty getEnabled() { return enabled; } /** * Returns the map of substitution items. * * @return the map of substitution items. */ public NamedDomainObjectContainer getItems() { return items; } /** * Accepts the DSL configuration for the {@code items} block, needed for defining * the block using the curly braces syntax in Gradle build scripts. * See the documentation on top of this class for more. * * @param configurationAction the configuration action for the {@code items} block */ public void items(Action> configurationAction) { configurationAction.execute(items); } /** * The class to model a single 'substitution' item within the extension. */ public abstract static class Substitution { /** * The substitution name. */ private final String name; /** * The substitution files property. */ private final Property files = getObjectfactory().property(String.class); /** * The substitution match property. */ private final Property match = getObjectfactory().property(String.class); /** * The substitution replace property. */ private final Property replace = getObjectfactory().property(String.class); /** * Returns an object factory instance. * * The instance is injected by Gradle as soon as this getter method is invoked. * * Using property injection * instead of constructor injection * has a few advantages: it allows Gradle to refer injecting the object until it's required and is safer for backward * compatibility (older versions can be supported). * * @return the object factory instance */ @Inject protected abstract ObjectFactory getObjectfactory(); /** * Constructor. * * This constructor is required as per the {@link NamedDomainObjectContainer} specification. * * @param name the substitution name */ public Substitution(String name) { super(); this.name = name; } /** * Returns the name read-only mandatory property. * * @return the name read-only mandatory property. */ public String getName() { return name; } /** * Returns the glob expression to select the text files to replace the matched strings into. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the glob expression to select the text files to replace the matched strings into. */ public Property getFiles() { return files; } /** * Returns the regular expression used to match the text to be replaced replace in files. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the regular expression used to match the text to be replaced replace in files. */ public Property getMatch() { return match; } /** * Returns the template expression defining the text to use when replacing all matched tokens. * * We provide an implementation of this method instead of using the abstract definition as it's * safer for old Gradle versions we support. * * @return the template expression defining the text to use when replacing all matched tokens. */ public Property getReplace() { return replace; } } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy