org.opencastproject.runtimeinfo.rest.RestFormatData Maven / Gradle / Ivy
/**
* Licensed to The Apereo Foundation under one or more contributor license
* agreements. See the NOTICE file distributed with this work for additional
* information regarding copyright ownership.
*
*
* The Apereo Foundation licenses this file to you under the Educational
* Community License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of the License
* at:
*
* http://opensource.org/licenses/ecl2.txt
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*
*/
package org.opencastproject.runtimeinfo.rest;
import javax.ws.rs.core.MediaType;
/**
* Represents an output format for a REST endpoint.
*/
public final class RestFormatData {
/**
* Default URL for the JSON format.
*/
public static final String JSON_URL = "http://www.json.org/";
/**
* Default URL for the XML format.
*/
public static final String XML_URL = "http://www.w3.org/XML/";
/**
* Name of the format, the value should be a constant from javax.ws.rs.core.MediaType or ExtendedMediaType (org.opencastproject.util.doc.rest.ExtendedMediaType).
*/
private String name;
/**
* URL to a page providing more information of the format. Currently only JSON and XML have a default URL.
*/
private String url;
/**
* Constructor that accepts a format name and finds the format's corresponding default URL and description. Currently
* only JSON and XML have a default URL.
*
* @param name
* the format name, the value should be a constant from javax.ws.rs.core.MediaType or ExtendedMediaType
* (org.opencastproject.util.doc.rest.ExtendedMediaType).
*
* @throws IllegalArgumentException
* when name is null
*/
public RestFormatData(String name) throws IllegalArgumentException {
if (name == null) {
throw new IllegalArgumentException("Name must not be null.");
}
this.name = name;
if ((name.equalsIgnoreCase(MediaType.TEXT_XML)) || (name.equalsIgnoreCase(MediaType.APPLICATION_XML))) {
url = XML_URL;
} else if (name.equalsIgnoreCase(MediaType.APPLICATION_JSON)) {
url = JSON_URL;
}
}
/**
* Return a string representation of this object.
*
* @return a string representation of this object
*/
@Override
public String toString() {
return name + ":(" + url + ")";
}
/**
* Return the name of this format.
*
* @return the name of this format
*/
public String getName() {
return name;
}
/**
* Return the default URL of this format.
*
* @return the default URL of this format.
*/
public String getUrl() {
return url;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy