/* === This file is part of Calamares - === * * Copyright 2014-2016, Teo Mrnjavac * Copyright 2018, 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 "GeoIPJSON.h" #include "utils/Logger.h" #include "utils/Variant.h" #include "utils/Yaml.h" #include namespace CalamaresUtils { namespace GeoIP { GeoIPJSON::GeoIPJSON(const QString& attribute) : Interface( attribute.isEmpty() ? QStringLiteral( "time_zone" ) : attribute ) { } /** @brief Indexes into a map @m by selectors @p l * * Each element of @p l is an index into map @m or a sub-map thereof, * so that "foo.bar.baz" looks up "baz" in the sub-map "bar" of sub-map * "foo" of @p m, like a regular JSON lookup would. */ static QString selectMap( const QVariantMap& m, const QStringList& l, int index) { if ( index >= l.count() ) return QString(); QString attributeName = l[index]; if ( index == l.count() - 1 ) return CalamaresUtils::getString( m, attributeName ); else { bool success = false; // bogus if ( m.contains( attributeName ) ) return selectMap( CalamaresUtils::getSubMap( m, attributeName, success ), l, index+1 ); return QString(); } } QString GeoIPJSON::rawReply( const QByteArray& data ) { try { YAML::Node doc = YAML::Load( data ); QVariant var = CalamaresUtils::yamlToVariant( doc ); if ( !var.isNull() && var.isValid() && var.type() == QVariant::Map ) { return selectMap( var.toMap(), m_element.split('.'), 0 ); } else cWarning() << "Invalid YAML data for GeoIPJSON"; } catch ( YAML::Exception& e ) { CalamaresUtils::explainYamlException( e, data, "GeoIP data"); } return QString(); } GeoIP::RegionZonePair GeoIPJSON::processReply( const QByteArray& data ) { return splitTZString( rawReply( data ) ); } } } // namespace