/** * Copyright (C) 2010 MediaShelf <http://www.yourmediashelf.com/> * * This file is part of fedora-client. * * fedora-client 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. * * fedora-client 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 fedora-client. If not, see <http://www.gnu.org/licenses/>. */ package com.yourmediashelf.fedora.client.request; import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.WebResource; import com.yourmediashelf.fedora.client.FedoraClient; import com.yourmediashelf.fedora.client.FedoraClientException; import com.yourmediashelf.fedora.client.response.FedoraResponse; import com.yourmediashelf.fedora.client.response.FedoraResponseImpl; /** * Builder for the GetDissemination method. * * @author Edwin Shin */ public class GetDissemination extends FedoraRequest<GetDissemination> { private final String pid; private final String sdefPid; private final String method; /** * * @param pid persistent identifier of the digital object * @param sdefPid persistent identifier of the sDef defining the methods * @param method method to invoke */ public GetDissemination(String pid, String sdefPid, String method) { this.pid = pid; this.sdefPid = sdefPid; this.method = method; } /** * Add a parameter required by the method. * * @param key * @param value * @return this builder */ public GetDissemination methodParam(String key, String value) { addQueryParam(key, value); return this; } @Override public FedoraResponse execute(FedoraClient fedora) throws FedoraClientException { WebResource wr = resource(fedora, String.format("objects/%s/methods/%s/%s", pid, sdefPid, method)); ClientResponse cr = wr.queryParams(getQueryParams()).get(ClientResponse.class); return new FedoraResponseImpl(cr); } }