/*
Copyright 2011-2014 Red Hat, Inc
This file is part of PressGang CCMS.
PressGang CCMS 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.
PressGang CCMS 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 PressGang CCMS. If not, see <http://www.gnu.org/licenses/>.
*/
package net.java.dev.webdav.jaxrs.xml.elements;
import java.net.URI;
import java.net.URISyntaxException;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlValue;
import net.java.dev.webdav.jaxrs.NullArgumentException;
/**
* WebDAV href XML Element.
*
* @author Markus KARG (mkarg@java.net)
*
* @see <a href="http://www.webdav.org/specs/rfc4918.html#ELEMENT_href">Chapter 14.7 "href XML Element" of RFC 4918 "HTTP Extensions for Web Distributed Authoring and Versioning (WebDAV)"</a>
*/
@XmlRootElement(name = "href")
public final class HRef {
@XmlValue
private String value;
@SuppressWarnings("unused")
private HRef() {
// For unmarshalling only.
}
public HRef(final URI uri) {
if (uri == null)
throw new NullArgumentException("uri");
this.value = uri.toString();
}
public HRef(final String value) {
this.value = value;
}
/**
* @return Value as a <code>URI</code> instance, if the content is a valid
* URI; <code>null</code> otherwise.
* @deprecated Since 1.1.1. Use {@link #getURI()} instead. Future releases
* will not contain this method anymore.
*/
@Deprecated
public final URI getUri() {
/*
* To preserve backwards compatibility, we must not throw an exception:
* Legacy code will not be prepared to catch it. Unfortunately this was
* a design fault in release 1.0 of this library that cannot be undone
* before release 2.0. The value is not a URI in all cases but may be
* any form of a relative reference, and such contain characters which
* would be illegal in an URI.
*/
try {
return this.getURI();
} catch (final URISyntaxException e) {
return null;
}
}
/**
* @return Value as a <code>URI</code> instance, if the value is a valid
* URI; <code>null</code> otherwise.
* @since 1.1.1
*/
public final URI getURI() throws URISyntaxException {
return new URI(this.value);
}
/**
* @since 1.1.1
*/
public final String getValue() {
return this.value;
}
}