/* * nheko Copyright (C) 2017 Konstantinos Sideris * * This program 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. * * This program 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 this program. If not, see . */ #include #include #include #include #include "AvatarProvider.h" #include "Cache.h" #include "Logging.h" #include "MatrixClient.h" static QPixmapCache avatar_cache; namespace AvatarProvider { void resolve(const QString &avatarUrl, int size, QObject *receiver, AvatarCallback callback) { avatar_cache.setCacheLimit(1024 * 1024); const auto cacheKey = avatarUrl + "_size_" + size; if (!cache::client()) return; if (avatarUrl.isEmpty()) return; QPixmap pixmap; if (avatar_cache.find(cacheKey, pixmap)) { nhlog::net()->info("cached pixmap {}", avatarUrl.toStdString()); callback(pixmap); return; } auto data = cache::client()->image(avatarUrl); if (!data.isNull()) { pixmap.loadFromData(data); avatar_cache.insert(cacheKey, pixmap); nhlog::net()->info("loaded pixmap from disk cache {}", avatarUrl.toStdString()); callback(pixmap); return; } auto proxy = std::make_shared(); QObject::connect(proxy.get(), &AvatarProxy::avatarDownloaded, receiver, [callback, cacheKey](const QByteArray &data) { QPixmap pm; pm.loadFromData(data); avatar_cache.insert(cacheKey, pm); callback(pm); }); mtx::http::ThumbOpts opts; opts.width = 256; opts.height = 256; opts.mxc_url = avatarUrl.toStdString(); http::client()->get_thumbnail( opts, [opts, proxy = std::move(proxy)](const std::string &res, mtx::http::RequestErr err) { if (err) { nhlog::net()->warn("failed to download avatar: {} - ({} {})", opts.mxc_url, mtx::errors::to_string(err->matrix_error.errcode), err->matrix_error.error); return; } cache::client()->saveImage(opts.mxc_url, res); nhlog::net()->info("downloaded pixmap {}", opts.mxc_url); emit proxy->avatarDownloaded(QByteArray(res.data(), res.size())); }); } void resolve(const QString &room_id, const QString &user_id, int size, QObject *receiver, AvatarCallback callback) { const auto key = QString("%1 %2").arg(room_id).arg(user_id); const auto avatarUrl = Cache::avatarUrl(room_id, user_id); const auto cacheKey = avatarUrl + "_size_" + size; if (!Cache::AvatarUrls.contains(key) || !cache::client()) return; resolve(avatarUrl, size, receiver, callback); } }