com.gooddata.connector.IntegrationProcessStatus Maven / Gradle / Ivy
/*
* Copyright (C) 2004-2017, GoodData(R) Corporation. All rights reserved.
* This source code is licensed under the BSD-style license found in the
* LICENSE.txt file in the root directory of this source tree.
*/
package com.gooddata.connector;
import static com.gooddata.util.Validate.notNullState;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.gooddata.util.GoodDataToStringBuilder;
import com.gooddata.util.ISODateTimeDeserializer;
import com.gooddata.util.ISODateTimeSerializer;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import org.joda.time.DateTime;
import org.springframework.web.util.UriTemplate;
import java.util.Map;
/**
* Connector process (i.e. single ETL run) status used in integration object. Deserialization only.
*/
@JsonIgnoreProperties(ignoreUnknown = true)
@JsonInclude(JsonInclude.Include.NON_NULL)
public class IntegrationProcessStatus {
public static final String URI = "/gdc/projects/{project}/connectors/{connector}/integration/processes/{process}";
public static final UriTemplate TEMPLATE = new UriTemplate(URI);
private static final String SELF_LINK = "self";
private final Status status;
private final DateTime started;
private final DateTime finished;
private final Map links;
@JsonCreator
protected IntegrationProcessStatus(@JsonProperty("status") Status status,
@JsonProperty("started") @JsonDeserialize(using = ISODateTimeDeserializer.class) DateTime started,
@JsonProperty("finished") @JsonDeserialize(using = ISODateTimeDeserializer.class) DateTime finished,
@JsonProperty("links") Map links) {
this.status = status;
this.started = started;
this.finished = finished;
this.links = links;
}
public Status getStatus() {
return status;
}
@JsonSerialize(using = ISODateTimeSerializer.class)
public DateTime getStarted() {
return started;
}
@JsonSerialize(using = ISODateTimeSerializer.class)
public DateTime getFinished() {
return finished;
}
/**
* Returns true when the connector process has already finished (no matter if it was successful).
* NOTE: It also returns false in case of inability to resolve the code (e.g. API change)
*
* @return true when the connector process has already finished, false otherwise
*/
@JsonIgnore
public boolean isFinished() {
return status != null && status.isFinished();
}
/**
* Returns true when the connector process failed.
* NOTE: It also returns false in case of inability to resolve the code (e.g. API change)
*
* @return true when the connector process failed, false otherwise
*/
@JsonIgnore
public boolean isFailed() {
return status != null && status.isFailed();
}
@JsonIgnore
public String getUri() {
return notNullState(links, "links").get(SELF_LINK);
}
@JsonIgnore
public String getId() {
return TEMPLATE.match(getUri()).get("process");
}
@Override
public String toString() {
return GoodDataToStringBuilder.defaultToString(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy