/*******************************************************************************
* Copyright (c) 2012-2017 Codenvy, S.A.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Codenvy, S.A. - initial API and implementation
*******************************************************************************/
package org.eclipse.che.plugin.docker.client.params.network;
import org.eclipse.che.plugin.docker.client.json.network.DisconnectContainer;
import javax.validation.constraints.NotNull;
import java.util.Objects;
import static java.util.Objects.requireNonNull;
/**
* Arguments holder for {@link org.eclipse.che.plugin.docker.client.DockerConnector#disconnectContainerFromNetwork(DisconnectContainerFromNetworkParams)}.
*
* @author Alexander Garagatyi
*/
public class DisconnectContainerFromNetworkParams {
private String netId;
private DisconnectContainer disconnectContainer;
private DisconnectContainerFromNetworkParams() {}
/**
* Creates arguments holder with required parameters.
*
* @param netId
* network identifier
* @param disconnectContainer
* container disconnection configuration
* @return arguments holder with required parameters
* @throws NullPointerException
* if {@code netId} or {@code disconnectContainer} is null
*/
public static DisconnectContainerFromNetworkParams create(@NotNull String netId, @NotNull DisconnectContainer disconnectContainer) {
return new DisconnectContainerFromNetworkParams().withNetworkId(netId)
.withDisconnectContainer(disconnectContainer);
}
/**
* Adds network identifier to this parameters.
*
* @param netId
* network identifier
* @return this params instance
* @throws NullPointerException
* if {@code netId} is null
*/
public DisconnectContainerFromNetworkParams withNetworkId(@NotNull String netId) {
requireNonNull(netId);
this.netId = netId;
return this;
}
/**
* Adds container identifier to this parameters.
*
* @param disconnectContainer
* container disconnection configuration
* @return this params instance
* @throws NullPointerException
* if {@code disconnectContainer} is null
*/
public DisconnectContainerFromNetworkParams withDisconnectContainer(@NotNull DisconnectContainer disconnectContainer) {
requireNonNull(disconnectContainer);
this.disconnectContainer = disconnectContainer;
return this;
}
public String getNetworkId() {
return netId;
}
public DisconnectContainer getDisconnectContainer() {
return disconnectContainer;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (!(obj instanceof DisconnectContainerFromNetworkParams)) {
return false;
}
final DisconnectContainerFromNetworkParams that = (DisconnectContainerFromNetworkParams)obj;
return Objects.equals(netId, that.netId)
&& Objects.equals(disconnectContainer, that.disconnectContainer);
}
@Override
public int hashCode() {
int hash = 7;
hash = 31 * hash + Objects.hashCode(netId);
hash = 31 * hash + Objects.hashCode(disconnectContainer);
return hash;
}
@Override
public String toString() {
return "DisconnectContainerFromNetworkParams{" +
"netId='" + netId + '\'' +
", disconnectContainer=" + disconnectContainer +
'}';
}
}