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

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

/*
 * File: Images.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.Collections;
import java.util.List;

/**
 * A representation of the Docker images command.
 * 

* Instances of {@link Images} are immutable, methods that * add options and configuration to this {@link Images} command return a * new instance of a {@link Images} 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 class Images extends CommandWithArgumentList { /** * The filter to apply to list untagged (dangling) images. */ public static final String FILTER_DANGLING = "dangling=true"; /** * The format string to use to show the image ID. */ public static final String FORMAT_ID = "{{.ID}}"; /** * The format string to use to show the image repository. */ public static final String FORMAT_REPOSITORY = "{{.Repository}}"; /** * The format string to use to show the image tag. */ public static final String FORMAT_TAG = "{{.Tag}}"; /** * The format string to use to show the image digest. */ public static final String FORMAT_DIGEST = "{{.Digest}}"; /** * The format string to use to show the elapsed time since the image was created. */ public static final String FORMAT_CREATED_SINCE = "{{.CreatedSince}}"; /** * The format string to use to show the time that the image was created. */ public static final String FORMAT_CREATED_AT = "{{.CreatedAt}}"; /** * The format string to use to show the image size. */ public static final String FORMAT_SIZE = "{{.Size}}"; /** * Create a {@link Images} command to list Docker images. */ private Images() { super("images", Collections.emptyList()); } /** * Create a {@link Images} command to list Docker images * for a specific [REPOSITORY[:TAG]] combination. */ private Images(String repoTag) { super("images", Collections.singletonList(repoTag)); } /** * Create an {@link Images} command with the specified {@link Arguments} * * @param arguments the command {@link Arguments} * @param tags the [REPOSITORY[:TAG]] to list */ private Images(Arguments arguments, List tags) { super(arguments, tags); } /** * Show all images (default hides intermediate images) * equates to the -a or --all argument. * * @return a new {@link Images} instance that is the same as this * instance with the --all option applied */ public Images all() { return withCommandArguments(Argument.of("--all")); } /** * Show image digests, equates to the --digests argument. * * @return a new {@link Images} instance that is the same as this * instance with the --digests option applied */ public Images digests() { return withCommandArguments(Argument.of("--digests")); } /** * Filter the image list (equates to the --filter argument). * * @param filters values that resolve to one or more valid filter arguments * * @return a new {@link Images} instance that is the same as this * instance with the --filter option applied */ public Images filter(Object... filters) { if (filters == null || filters.length == 0) { return this; } return withCommandArguments(Argument.of("--filter", '=', new Argument.Multiple(filters))); } /** * Format the output (equates to the --format argument). * * @param formats values that resolve to one or more valid format arguments * * @return a new {@link Images} instance that is the same as this * instance with the --format option applied */ public Images format(Object... formats) { if (formats == null || formats.length == 0) { return this; } return withCommandArguments(Argument.of("--format", '=', new Argument.Multiple(formats))); } /** * Do not truncate output, equates to the --no-trunc argument. * * @return a new {@link Images} instance that is the same as this * instance with the --no-trunc option applied */ public Images noTruncate() { return withCommandArguments(Argument.of("--no-trunc")); } /** * Only show numeric IDs, equates to the --quiet argument. * * @return a new {@link Images} instance that is the same as this * instance with the --quiet option applied */ public Images quiet() { return withCommandArguments(Argument.of("--quiet")); } /** * Create a {@link Images} command to view all images. * * @return a {@link Images} command to view all images */ public static Images list() { return new Images(); } /** * Create a {@link Images} command to view images for * a specific [REPOSITORY[:TAG]] combination. * * @param repoTag the [REPOSITORY[:TAG]] combination to * list images for * * @return a {@link Images} command to view images * for a specific [REPOSITORY[:TAG]] combination */ public static Images forRepo(String repoTag) { return new Images(repoTag); } @Override protected Images withCommandArguments(List endArgs, Argument... args) { return new Images(getCommandArguments().with(args), endArgs); } @Override protected Images withoutCommandArguments(List endArgs, Argument... args) { return new Images(getCommandArguments().without(args), endArgs); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy