All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.redlink.geocoding.nominatim.NominatimBuilder Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2017-2022 Redlink GmbH.
 *
 * 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 io.redlink.geocoding.nominatim;

import java.io.IOException;
import java.io.InputStream;
import java.net.Proxy;
import java.net.URI;
import java.net.URL;
import java.util.LinkedHashMap;
import java.util.Locale;
import java.util.Map;
import java.util.Objects;
import java.util.Properties;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * A Builder for NominatimGeocoder
 */
public class NominatimBuilder {

    private static final Logger LOG = LoggerFactory.getLogger(NominatimBuilder.class);

    private String baseUrl;
    private String email = null;
    private String userAgent = null;
    private Locale locale;
    private Proxy proxy = null;
    private int maxQps = -1;

    private String geocodeEndpoint = NominatimGeocoder.DEFAULT_GEOCODE_ENDPOINT;
    private String reverseEndpoint = NominatimGeocoder.DEFAULT_REVERSE_ENDPOINT;
    private String lookupEndpoint = NominatimGeocoder.DEFAULT_LOOKUP_ENDPOINT;

    private final Map customQuery = new LinkedHashMap<>();
    private final Map customHeaders = new LinkedHashMap<>();

    /**
     * @deprecated use {@link NominatimGeocoder#builder()}
     */
    @Deprecated(since = "2.0.2")
    public NominatimBuilder() {
        baseUrl = NominatimGeocoder.PUBLIC_NOMINATIM_SERVER;
        locale = Locale.getDefault(Locale.Category.DISPLAY);
    }

    public NominatimGeocoder create() {
        return new NominatimGeocoder(baseUrl, locale, email, proxy, maxQps,
                new ServiceConfiguration(
                        geocodeEndpoint, reverseEndpoint, lookupEndpoint,
                        customQuery, customHeaders,
                        Objects.requireNonNullElseGet(userAgent, NominatimBuilder::createUserAgent))
        );
    }

    public NominatimBuilder setBaseUrl(URI baseUrl) {
        return setBaseUrl(baseUrl.toASCIIString());
    }

    public NominatimBuilder setBaseUrl(URL baseUrl) {
        return setBaseUrl(baseUrl.toExternalForm());
    }

    public NominatimBuilder setBaseUrl(String baseUrl) {
        this.baseUrl = baseUrl;
        return this;
    }

    public NominatimBuilder setProxy(Proxy proxy) {
        this.proxy = proxy;
        return this;
    }

    public NominatimBuilder setQueryRateLimit(int maxQps) {
        this.maxQps = maxQps;
        return this;
    }

    public NominatimBuilder setLocale(String lang) {
        this.locale = Locale.forLanguageTag(lang);
        return this;
    }

    public NominatimBuilder setLocale(Locale lang) {
        this.locale = lang;
        return this;
    }

    public NominatimBuilder setEmail(String email) {
        this.email = email;
        return this;
    }

    public NominatimBuilder setUserAgent(String userAgent) {
        this.userAgent = userAgent;
        return this;
    }

    public NominatimBuilder setGeocodeEndpoint(String geocodeEndpoint) {
        this.geocodeEndpoint = geocodeEndpoint;
        return this;
    }

    public NominatimBuilder setReverseEndpoint(String reverseEndpoint) {
        this.reverseEndpoint = reverseEndpoint;
        return this;
    }

    public NominatimBuilder setLookupEndpoint(String lookupEndpoint) {
        this.lookupEndpoint = lookupEndpoint;
        return this;
    }

    public NominatimBuilder setStaticQueryParam(String key, String value) {
        this.customQuery.put(key, value);
        return this;
    }

    public NominatimBuilder setStaticHeader(String headerName, String headerValue) {
        this.customHeaders.put(headerName, headerValue);
        return this;
    }

    private static String createUserAgent() {
        final String userAgent = String.format("redlink-geocoding/%s (%s; +%s)",
                readLibVersion(),
                ServiceConfiguration.class.getModule().getName(),
                "https://github.com/redlink-gmbh/redlink-geocoding"
        );
        LOG.debug("No User-Agent provided, using fallback to {}", userAgent);
        return userAgent;
    }

    private static String readLibVersion() {
        final String fallbackVersion = "0.0.0-SNAPSHOT";
        final Properties p;
        try (InputStream pomProperties = ServiceConfiguration.class
                .getModule()
                .getResourceAsStream("/META-INF/maven/io.redlink.geocoding/geocoding-osm/pom.properties")) {
            p = new Properties();
            if (pomProperties != null) {
                p.load(pomProperties);
            }
            return p.getProperty("version", fallbackVersion);
        } catch (IOException e) {
            LOG.warn("Could not determine library-version, fallback to {}", fallbackVersion, e);
            return fallbackVersion;
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy