Java tutorial
/* * Copyright 2013 Global Biodiversity Information Facility (GBIF) * * Licensed under the Apache 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://www.apache.org/licenses/LICENSE-2.0 * * 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.gbif.registry.metasync.util.converter; import java.net.URI; import java.net.URISyntaxException; import org.apache.commons.beanutils.Converter; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import static com.google.common.base.Preconditions.checkArgument; import static com.google.common.base.Preconditions.checkNotNull; /** * Used by commons-digester (via commons-beanutils) to convert Strings into {@link URI}s. */ public class UriConverter implements Converter { private static final Logger LOG = LoggerFactory.getLogger(UriConverter.class); @Override public Object convert(Class type, Object value) { checkNotNull(type, "type cannot be null"); checkArgument(type.equals(URI.class), "Conversion target should be org.gbif.api.vocabulary.Language, but is %s", type.getClass()); checkArgument(String.class.isAssignableFrom(value.getClass()), "Value should be a string, but is a %s", value.getClass()); try { return new URI((String) value); } catch (URISyntaxException e) { LOG.warn("Invalid URL: [{}]", value, e); } return null; } }