File indexing completed on 2024-09-15 03:37:48

0001 /*
0002     SPDX-FileCopyrightText: 2021 Volker Krause <vkrause@kde.org>
0003     SPDX-License-Identifier: LGPL-2.0-or-later
0004 */
0005 
0006 #ifndef KGEOURIHANDLER_H
0007 #define KGEOURIHANDLER_H
0008 
0009 #include <QString>
0010 
0011 class QUrl;
0012 
0013 /** Fallback handler for geo: URIs by forwarding them to a web service.
0014  *
0015  *  This handles three cases of geo: URIs:
0016  *  - when containing a query argument, the query URL template is used
0017  *  - when containing valid WGS-84 coordinates, the coordinate URL template is used
0018  *  - otherwise the fallback URL is returned
0019  *
0020  *  URL templates can contain any number of the following placeholders in angle brackets:
0021  *  - @c LAT - the latitude
0022  *  - @c LON - the longitude
0023  *  - @c Q - the query string
0024  *  - @c Z - the zoom level for a Web Mercator map projection
0025  *
0026  *  @see https://en.wikipedia.org/wiki/Geo_URI_scheme
0027  *  @see https://datatracker.ietf.org/doc/html/rfc5870
0028  */
0029 class KGeoUriHandler
0030 {
0031 public:
0032     void setCoordinateTemplate(const QString &coordTmpl);
0033     void setQueryTemplate(const QString &queryTmpl);
0034     void setFallbackUrl(const QString &fallbackUrl);
0035 
0036     QString handleUri(const QUrl &geoUri);
0037 
0038 private:
0039     QString m_coordTmpl;
0040     QString m_queryTmpl;
0041     QString m_fallbackUrl;
0042 };
0043 
0044 #endif // KGEOURIHANDLER_H