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

com.oracle.bedrock.runtime.docker.commands.Remove Maven / Gradle / Ivy

/*
 * File: Remove.java
 *
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * The contents of this file are subject to the terms and conditions of 
 * the Common Development and Distribution License 1.0 (the "License").
 *
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the License by consulting the LICENSE.txt file
 * distributed with this file, or by consulting https://oss.oracle.com/licenses/CDDL
 *
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file LICENSE.txt.
 *
 * MODIFICATIONS:
 * If applicable, add the following below the License Header, with the fields
 * enclosed by brackets [] replaced by your own identifying information:
 * "Portions Copyright [year] [name of copyright owner]"
 */

package com.oracle.bedrock.runtime.docker.commands;

import com.oracle.bedrock.runtime.options.Argument;
import com.oracle.bedrock.runtime.options.Arguments;

import java.util.Arrays;
import java.util.Collections;
import java.util.List;

/**
 * A representation of the Docker rm and rmi commands to remove containers,
 * container links and images.
 * 

* Instances of {@link Remove} are immutable, methods that * add options and configuration to this {@link Remove} command return a * new instance of a {@link Remove} command with the modifications applied. *

* Copyright (c) 2016. All Rights Reserved. Oracle Corporation.
* Oracle is a registered trademark of Oracle Corporation and/or its affiliates. * * @author Jonathan Knight */ public abstract class Remove extends CommandWithArgumentList { /** * Create a {@link Remove} command with the specified {@link Arguments} * and items to be removed. * * @param arguments the command {@link Arguments} * @param names the names of the items to remove */ private Remove(Arguments arguments, List names) { super(arguments, names); } /** * Create a {@link Remove} command. * * @param command the name of the command (rm or rmi) * @param names the names of the items to be removed */ private Remove(String command, List names) { super(command, names); } /** * Create a {@link RemoveContainer} command to remove specific containers. * * @param names values that will resolve to a set of tags for containers * to be removed * * @return a {@link RemoveContainer} command to remove specific containers */ public static RemoveContainer containers(Object... names) { return containers(Arrays.asList(names)); } /** * Create a {@link RemoveContainer} command to remove specific containers. * * @param names a {@link List} of values that will resolve to a set of * tags for containers to be removed * * @return a {@link RemoveContainer} command to remove specific containers */ public static RemoveContainer containers(List names) { return new RemoveContainer(names); } /** * Create a {@link Remove} command to remove a link between two containers. * * @param first the name of the first container * @param second the name of the second container * * @return a {@link Remove} command to remove a link between two containers */ public static Remove link(String first, String second) { List names = Collections.singletonList(first + '/' + second); return new RemoveLink(names).withCommandArguments(Argument.of("--link")); } /** * Create a {@link RemoveImage} command to remove specific images. * * @param tags values that will resolve to a set of tags for images to be removed * * @return a {@link RemoveImage} command to remove specific images */ public static RemoveImage images(Object... tags) { return images(Arrays.asList(tags)); } /** * Create a {@link RemoveImage} command to remove specific images. * * @param tags a {@link List} of values that will resolve to a set of * tags for images to be removed * * @return a {@link RemoveImage} command to remove specific images */ public static RemoveImage images(List tags) { return new RemoveImage(tags); } /** * A representation of a Docker command to remove one or more * containers (equates to the Docker rm command). */ public static class RemoveContainer extends Remove { /** * Create a {@link RemoveContainer} command to reove * the specified containers. * * @param containers the names of the containers to remove */ private RemoveContainer(List containers) { super("rm", containers); } /** * Create a {@link Remove} command with the specified {@link Arguments} * and containers to be removed. * * @param arguments the command {@link Arguments} * @param containers the names of the containers to remove */ private RemoveContainer(Arguments arguments, List containers) { super(arguments, containers); } /** * Force removal of the container (equates to the --force argument). * * @return a new {@link RemoveContainer} instance that is the same as this * instance with the --force option applied */ public RemoveContainer force() { return force(true); } /** * Force removal of the container (equates to the --force argument). * * @param force true to add the --force option or false * to remove the --force option * * @return a new {@link RemoveContainer} instance that is the same as this * instance with the --force option applied */ public RemoveContainer force(boolean force) { if (force) { return withCommandArguments(Argument.of("--force")); } return withoutCommandArguments(Argument.of("--force")); } /** * Remove the volumes associated with the container (equates to the --volumes argument). * * @return a new {@link RemoveContainer} instance that is the same as this * instance with the --volumes option applied */ public RemoveContainer andVolumes() { return andVolumes(true); } /** * Remove the volumes associated with the container (equates to the --volumes argument). * * @param remove true to add the --volumes option, false to * remove the --volumes option * * @return a new {@link RemoveContainer} instance that is the same as this * instance with the --volumes option applied */ public RemoveContainer andVolumes(boolean remove) { if (remove) { return withCommandArguments(Argument.of("--volumes")); } return withoutCommandArguments(Argument.of("--volumes")); } @Override protected RemoveContainer withCommandArguments(List containers, Argument... args) { return new RemoveContainer(getCommandArguments().with(args), containers); } @Override protected RemoveContainer withoutCommandArguments(List names, Argument... args) { return new RemoveContainer(getCommandArguments().without(args), names); } } /** * A representation of a Docker command to remove an image. */ public static class RemoveImage extends Remove { /** * Create a {@link RemoveImage} command to remove the specified images. * * @param images the names of the images to remove */ private RemoveImage(List images) { super("rmi", images); } /** * Create a {@link RemoveImage} command with the specified {@link Arguments} * and images to be removed. * * @param arguments the command {@link Arguments} * @param names the names of the images to remove */ private RemoveImage(Arguments arguments, List names) { super(arguments, names); } /** * Force removal of the image (equates to the --force argument). * * @return a new {@link RemoveImage} instance that is the same as this * instance with the --force option applied */ public RemoveImage force() { return force(true); } /** * Force removal of the image (equates to the --force argument). * * @param force true to add the --force option or false * to remove the --force option * * @return a new {@link RemoveImage} instance that is the same as this * instance with the --force option applied */ public RemoveImage force(boolean force) { if (force) { return withCommandArguments(Argument.of("--force")); } return withoutCommandArguments(Argument.of("--force")); } /** * Do not delete untagged parents (equates to the --no-prune argument). * * @return a new {@link RemoveImage} instance that is the same as this * instance with the --no-prune option applied */ public RemoveImage noPrune() { return noPrune(true); } /** * Do not delete untagged parents (equates to the --no-prune argument). * * @param noPrune true to add the --no-prune option or false * to remove the --no-prune option * * @return a new {@link RemoveImage} instance that is the same as this * instance with the --no-prune option applied */ public RemoveImage noPrune(boolean noPrune) { if (noPrune) { return withCommandArguments(Argument.of("--no-prune")); } return withoutCommandArguments(Argument.of("--no-prune")); } @Override protected RemoveImage withCommandArguments(List images, Argument... args) { return new RemoveImage(getCommandArguments().with(args), images); } @Override protected RemoveImage withoutCommandArguments(List names, Argument... args) { return new RemoveImage(getCommandArguments().without(args), names); } } /** * A representation of a Docker command to remove a link between two * containers (equates to the Docker rm --link containerA/contaunerB command). */ public static class RemoveLink extends Remove { private RemoveLink(List names) { super("rm", names); } /** * Create a {@link RemoveLink} command with the specified {@link Arguments} * and containers to be un-linked. * * @param arguments the command {@link Arguments} * @param names the names of the containers to be unlinked */ private RemoveLink(Arguments arguments, List names) { super(arguments, names); } @Override protected RemoveLink withCommandArguments(List containers, Argument... args) { return new RemoveLink(getCommandArguments().with(args), containers); } @Override protected RemoveLink withoutCommandArguments(List names, Argument... args) { return new RemoveLink(getCommandArguments().without(args), names); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy