/*
* Copyright (C) 2016 TIBCO Jaspersoft Corporation. All rights reserved.
* http://community.jaspersoft.com/project/mobile-sdk-android
*
* Unless you have purchased a commercial license agreement from TIBCO Jaspersoft,
* the following license terms apply:
*
* This program is part of TIBCO Jaspersoft Mobile SDK for Android.
*
* TIBCO Jaspersoft Mobile SDK is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* TIBCO Jaspersoft Mobile SDK is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with TIBCO Jaspersoft Mobile SDK for Android. If not, see
* <http://www.gnu.org/licenses/lgpl>.
*/
package com.jaspersoft.android.sdk.service.data.schedule;
import com.jaspersoft.android.sdk.network.entity.report.ReportParameter;
import com.jaspersoft.android.sdk.service.internal.Preconditions;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* @author Tom Koptel
* @since 2.3
*/
public class JobSource {
private final String uri;
private final List<ReportParameter> parameters;
JobSource(Builder builder) {
uri = builder.uri;
parameters = builder.parameters;
}
@NotNull
public String getUri() {
return uri;
}
@NotNull
public List<ReportParameter> getParameters() {
return parameters;
}
public Builder newBuilder() {
return new JobSource.Builder(this);
}
public static class Builder {
private String uri;
private List<ReportParameter> parameters;
public Builder() {
parameters = new ArrayList<>();
}
private Builder(JobSource jobSource) {
uri = jobSource.uri;
parameters = jobSource.parameters;
}
/**
* Allows to specify resource uri that will be used to schedule job
*
* @param uri unique identifier of resources in JRS domain
* @return builder for convenient configuration
*/
public Builder withUri(@NotNull String uri) {
this.uri = Preconditions.checkNotNull(uri, "Source uri should not be null");
return this;
}
/**
* Allows to specify report params that specify exact data requested by user
*
* @param parameters list of key/value pair where key corresponds to control state id and value represented by set of values
* @return builder for convenient configuration
*/
public Builder withParameters(@Nullable List<ReportParameter> parameters) {
if (parameters != null) {
this.parameters = Collections.unmodifiableList(parameters);
}
return this;
}
public JobSource build() {
assertState();
return new JobSource(this);
}
private void assertState() {
Preconditions.checkNotNull(uri, "Source can not be created without uri");
}
}
}