/* === This file is part of Calamares - === * * Copyright 2019, Adriaan de Groot * * Calamares is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Calamares 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Calamares. If not, see . */ #include "Handler.h" #include "GeoIPJSON.h" #if defined( QT_XML_LIB ) #include "GeoIPXML.h" #endif #include "network/Manager.h" #include "utils/Logger.h" #include "utils/NamedEnum.h" #include "utils/Variant.h" #include static const NamedEnumTable< CalamaresUtils::GeoIP::Handler::Type >& handlerTypes() { using Type = CalamaresUtils::GeoIP::Handler::Type; // *INDENT-OFF* // clang-format off static const NamedEnumTable names{ { QStringLiteral( "none" ), Type::None }, { QStringLiteral( "json" ), Type::JSON }, { QStringLiteral( "xml" ), Type::XML } }; // *INDENT-ON* // clang-format on return names; } namespace CalamaresUtils { namespace GeoIP { Handler::Handler() : m_type( Type::None ) { } Handler::Handler( const QString& implementation, const QString& url, const QString& selector ) : m_type( Type::None ) , m_url( url ) , m_selector( selector ) { bool ok = false; m_type = handlerTypes().find( implementation, ok ); if ( !ok ) { cWarning() << "GeoIP style" << implementation << "is not recognized."; } else if ( m_type == Type::None ) { cWarning() << "GeoIP style *none* does not do anything."; } #if !defined( QT_XML_LIB ) else if ( m_type == Type::XML ) { m_type = Type::None; cWarning() << "GeoIP style *xml* is not supported in this version of Calamares."; } #endif } Handler::~Handler() {} static std::unique_ptr< Interface > create_interface( Handler::Type t, const QString& selector ) { switch ( t ) { case Handler::Type::None: return nullptr; case Handler::Type::JSON: return std::make_unique< GeoIPJSON >( selector ); case Handler::Type::XML: #if defined( QT_XML_LIB ) return std::make_unique< GeoIPXML >( selector ); #else return nullptr; #endif } NOTREACHED return nullptr; } static RegionZonePair do_query( Handler::Type type, const QString& url, const QString& selector ) { const auto interface = create_interface( type, selector ); if ( !interface ) { return RegionZonePair(); } return interface->processReply( CalamaresUtils::Network::Manager::instance().synchronousGet( url ) ); } static QString do_raw_query( Handler::Type type, const QString& url, const QString& selector ) { const auto interface = create_interface( type, selector ); if ( !interface ) { return QString(); } return interface->rawReply( CalamaresUtils::Network::Manager::instance().synchronousGet( url ) ); } RegionZonePair Handler::get() const { if ( !isValid() ) { return RegionZonePair(); } return do_query( m_type, m_url, m_selector ); } QFuture< RegionZonePair > Handler::query() const { Handler::Type type = m_type; QString url = m_url; QString selector = m_selector; return QtConcurrent::run( [=] { return do_query( type, url, selector ); } ); } QString Handler::getRaw() const { if ( !isValid() ) { return QString(); } return do_raw_query( m_type, m_url, m_selector ); } QFuture< QString > Handler::queryRaw() const { Handler::Type type = m_type; QString url = m_url; QString selector = m_selector; return QtConcurrent::run( [=] { return do_raw_query( type, url, selector ); } ); } } // namespace GeoIP } // namespace CalamaresUtils