Skip to content
This repository has been archived by the owner on Mar 31, 2022. It is now read-only.

Commit

Permalink
* Add arbitrary build param support
Browse files Browse the repository at this point in the history
  • Loading branch information
Dylan Schell committed Aug 1, 2018
1 parent 49782a2 commit 21f2206
Showing 1 changed file with 10 additions and 2 deletions.
12 changes: 10 additions & 2 deletions plugin/src/main/java/com/spotify/plugin/dockerfile/BuildMojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,9 @@ public class BuildMojo extends AbstractDockerMojo {
@Parameter(property = "dockerfile.buildArgs")
private Map<String,String> buildArgs;

@Parameter(property = "dockerfile.buildParams")
private Map<String,String> buildParams;

@Override
public void execute(DockerClient dockerClient)
throws MojoExecutionException, MojoFailureException {
Expand All @@ -104,7 +107,7 @@ public void execute(DockerClient dockerClient)

final String imageId = buildImage(
dockerClient, log, verbose, contextDirectory, repository, tag, pullNewerImage, noCache,
buildArgs);
buildParams, buildArgs);

if (imageId == null) {
log.warn("Docker build was successful, but no image was built");
Expand Down Expand Up @@ -136,6 +139,7 @@ static String buildImage(@Nonnull DockerClient dockerClient,
@Nonnull String tag,
boolean pullNewerImage,
boolean noCache,
@Nullable Map<String,String> buildParams,
@Nullable Map<String,String> buildArgs)
throws MojoExecutionException, MojoFailureException {

Expand All @@ -156,7 +160,11 @@ static String buildImage(@Nonnull DockerClient dockerClient,
if (noCache) {
buildParameters.add(DockerClient.BuildParam.noCache());
}

if (buildParams != null) {
for (Map.Entry<String,String> e: buildParams.entrySet()) {
buildParameters.add(DockerClient.BuildParam.create(e.getKey(),e.getValue()));
}
}
if (buildArgs != null && !buildArgs.isEmpty()) {
try {
final String encodedBuildArgs = URLEncoder.encode(new Gson().toJson(buildArgs), "utf-8");
Expand Down

0 comments on commit 21f2206

Please sign in to comment.