Removed dirty hack in InternetModel; added "radiobrowser:" url handler; rework station play callback
This commit is contained in:
parent
cd062f1d8b
commit
6a45edaa34
|
@ -194,6 +194,7 @@ set(SOURCES
|
||||||
internet/intergalacticfm/intergalacticfmurlhandler.cpp
|
internet/intergalacticfm/intergalacticfmurlhandler.cpp
|
||||||
internet/radiobrowser/radiobrowserservice.cpp
|
internet/radiobrowser/radiobrowserservice.cpp
|
||||||
internet/radiobrowser/radiobrowsersettingspage.cpp
|
internet/radiobrowser/radiobrowsersettingspage.cpp
|
||||||
|
internet/radiobrowser/radiobrowserurlhandler.cpp
|
||||||
internet/subsonic/subsonicservice.cpp
|
internet/subsonic/subsonicservice.cpp
|
||||||
internet/subsonic/subsonicsettingspage.cpp
|
internet/subsonic/subsonicsettingspage.cpp
|
||||||
internet/subsonic/subsonicurlhandler.cpp
|
internet/subsonic/subsonicurlhandler.cpp
|
||||||
|
@ -512,6 +513,7 @@ set(HEADERS
|
||||||
internet/intergalacticfm/intergalacticfmurlhandler.h
|
internet/intergalacticfm/intergalacticfmurlhandler.h
|
||||||
internet/radiobrowser/radiobrowserservice.h
|
internet/radiobrowser/radiobrowserservice.h
|
||||||
internet/radiobrowser/radiobrowsersettingspage.h
|
internet/radiobrowser/radiobrowsersettingspage.h
|
||||||
|
internet/radiobrowser/radiobrowserurlhandler.h
|
||||||
internet/subsonic/subsonicservice.h
|
internet/subsonic/subsonicservice.h
|
||||||
internet/subsonic/subsonicsettingspage.h
|
internet/subsonic/subsonicsettingspage.h
|
||||||
internet/subsonic/subsonicurlhandler.h
|
internet/subsonic/subsonicurlhandler.h
|
||||||
|
|
|
@ -99,7 +99,6 @@ void RegisterMetaTypes() {
|
||||||
qRegisterMetaType<SomaFMService::Stream>("SomaFMService::Stream");
|
qRegisterMetaType<SomaFMService::Stream>("SomaFMService::Stream");
|
||||||
qRegisterMetaType<IntergalacticFMService::Stream>(
|
qRegisterMetaType<IntergalacticFMService::Stream>(
|
||||||
"IntergalacticFMService::Stream");
|
"IntergalacticFMService::Stream");
|
||||||
qRegisterMetaType<RadioBrowserService::Stream>("RadioBrowserService::Stream");
|
|
||||||
qRegisterMetaType<SongList>("SongList");
|
qRegisterMetaType<SongList>("SongList");
|
||||||
qRegisterMetaType<Song>("Song");
|
qRegisterMetaType<Song>("Song");
|
||||||
qRegisterMetaTypeStreamOperators<DigitallyImportedClient::Channel>(
|
qRegisterMetaTypeStreamOperators<DigitallyImportedClient::Channel>(
|
||||||
|
@ -110,8 +109,6 @@ void RegisterMetaTypes() {
|
||||||
"SomaFMService::Stream");
|
"SomaFMService::Stream");
|
||||||
qRegisterMetaTypeStreamOperators<IntergalacticFMService::Stream>(
|
qRegisterMetaTypeStreamOperators<IntergalacticFMService::Stream>(
|
||||||
"IntergalacticFMService::Stream");
|
"IntergalacticFMService::Stream");
|
||||||
qRegisterMetaTypeStreamOperators<RadioBrowserService::Stream>(
|
|
||||||
"RadioBrowserService::Stream");
|
|
||||||
qRegisterMetaType<SubdirectoryList>("SubdirectoryList");
|
qRegisterMetaType<SubdirectoryList>("SubdirectoryList");
|
||||||
qRegisterMetaType<Subdirectory>("Subdirectory");
|
qRegisterMetaType<Subdirectory>("Subdirectory");
|
||||||
qRegisterMetaType<QList<QUrl>>("QList<QUrl>");
|
qRegisterMetaType<QList<QUrl>>("QList<QUrl>");
|
||||||
|
|
|
@ -29,18 +29,12 @@ RadioBrowserSearchProvider::RadioBrowserSearchProvider(
|
||||||
Init(RadioBrowserService::kServiceName, "radiobrowser",
|
Init(RadioBrowserService::kServiceName, "radiobrowser",
|
||||||
IconLoader::Load("radiobrowser", IconLoader::Provider),
|
IconLoader::Load("radiobrowser", IconLoader::Provider),
|
||||||
WantsDelayedQueries);
|
WantsDelayedQueries);
|
||||||
connect(service_,
|
connect(service_, &RadioBrowserService::SearchFinished, this,
|
||||||
SIGNAL(SearchFinished(int, RadioBrowserService::StreamList)),
|
&RadioBrowserSearchProvider::SearchFinishedSlot);
|
||||||
SLOT(SearchFinishedSlot(int, RadioBrowserService::StreamList)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void RadioBrowserSearchProvider::SearchAsync(int id, const QString& query) {
|
void RadioBrowserSearchProvider::SearchAsync(int id, const QString& query) {
|
||||||
PendingState state;
|
service_->Search(id, query, kSearchStationLimit);
|
||||||
state.orig_id_ = id;
|
|
||||||
state.tokens_ = TokenizeQuery(query);
|
|
||||||
|
|
||||||
const QString query_string = state.tokens_.join(" ");
|
|
||||||
service_->Search(id, query_string, kSearchStationLimit);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void RadioBrowserSearchProvider::SearchFinishedSlot(
|
void RadioBrowserSearchProvider::SearchFinishedSlot(
|
||||||
|
@ -57,10 +51,3 @@ void RadioBrowserSearchProvider::SearchFinishedSlot(
|
||||||
emit ResultsAvailable(search_id, ret);
|
emit ResultsAvailable(search_id, ret);
|
||||||
emit SearchFinished(search_id);
|
emit SearchFinished(search_id);
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
void RadioBrowserSearchProvider::ShowConfig() {
|
|
||||||
if (service_) {
|
|
||||||
return service_->ShowConfig();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
|
@ -28,7 +28,6 @@ class RadioBrowserSearchProvider : public SearchProvider {
|
||||||
RadioBrowserSearchProvider(Application* app, RadioBrowserService* service,
|
RadioBrowserSearchProvider(Application* app, RadioBrowserService* service,
|
||||||
QObject* parent = nullptr);
|
QObject* parent = nullptr);
|
||||||
void SearchAsync(int id, const QString& query) override;
|
void SearchAsync(int id, const QString& query) override;
|
||||||
// void ShowConfig() override;
|
|
||||||
InternetService* internet_service() override { return service_; }
|
InternetService* internet_service() override { return service_; }
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
|
|
@ -332,10 +332,6 @@ QMimeData* InternetModel::mimeData(const QModelIndexList& indexes) const {
|
||||||
|
|
||||||
if (urls.isEmpty()) return nullptr;
|
if (urls.isEmpty()) return nullptr;
|
||||||
|
|
||||||
for (const QModelIndex& index : new_indexes) {
|
|
||||||
InternetModel::ServiceForIndex(index)->ItemNowPlaying(itemFromIndex(index));
|
|
||||||
}
|
|
||||||
|
|
||||||
InternetMimeData* data = new InternetMimeData(this);
|
InternetMimeData* data = new InternetMimeData(this);
|
||||||
data->setUrls(urls);
|
data->setUrls(urls);
|
||||||
data->indexes = new_indexes;
|
data->indexes = new_indexes;
|
||||||
|
|
|
@ -27,7 +27,6 @@
|
||||||
#include <QtDebug>
|
#include <QtDebug>
|
||||||
|
|
||||||
#include "core/application.h"
|
#include "core/application.h"
|
||||||
#include "core/closure.h"
|
|
||||||
#include "core/logging.h"
|
#include "core/logging.h"
|
||||||
#include "core/network.h"
|
#include "core/network.h"
|
||||||
#include "core/player.h"
|
#include "core/player.h"
|
||||||
|
@ -35,6 +34,7 @@
|
||||||
#include "core/utilities.h"
|
#include "core/utilities.h"
|
||||||
#include "globalsearch/globalsearch.h"
|
#include "globalsearch/globalsearch.h"
|
||||||
#include "globalsearch/radiobrowsersearchprovider.h"
|
#include "globalsearch/radiobrowsersearchprovider.h"
|
||||||
|
#include "radiobrowserurlhandler.h"
|
||||||
#include "ui/iconloader.h"
|
#include "ui/iconloader.h"
|
||||||
|
|
||||||
bool operator<(const RadioBrowserService::Stream& a,
|
bool operator<(const RadioBrowserService::Stream& a,
|
||||||
|
@ -44,6 +44,7 @@ bool operator<(const RadioBrowserService::Stream& a,
|
||||||
|
|
||||||
const char* RadioBrowserService::kServiceName = "Radio-Browser.info";
|
const char* RadioBrowserService::kServiceName = "Radio-Browser.info";
|
||||||
const char* RadioBrowserService::kSettingsGroup = "RadioBrowser";
|
const char* RadioBrowserService::kSettingsGroup = "RadioBrowser";
|
||||||
|
const char* RadioBrowserService::kSchemeName = "radiobrowser";
|
||||||
|
|
||||||
QString RadioBrowserService::SearchUrl = "%1/json/stations/byname/%2?limit=%3";
|
QString RadioBrowserService::SearchUrl = "%1/json/stations/byname/%2?limit=%3";
|
||||||
QString RadioBrowserService::PlayClickUrl = "%1/json/url/%2";
|
QString RadioBrowserService::PlayClickUrl = "%1/json/url/%2";
|
||||||
|
@ -73,8 +74,11 @@ RadioBrowserService::RadioBrowserService(Application* app,
|
||||||
context_menu_(nullptr),
|
context_menu_(nullptr),
|
||||||
network_(new NetworkAccessManager(this)),
|
network_(new NetworkAccessManager(this)),
|
||||||
name_(kServiceName),
|
name_(kServiceName),
|
||||||
|
url_scheme_(kSchemeName),
|
||||||
|
url_handler_(new RadioBrowserUrlHandler(app, this, this)),
|
||||||
homepage_url_(QUrl("https://www.radio-browser.info")),
|
homepage_url_(QUrl("https://www.radio-browser.info")),
|
||||||
icon_(IconLoader::Load("radiobrowser", IconLoader::Provider)) {
|
icon_(IconLoader::Load("radiobrowser", IconLoader::Provider)) {
|
||||||
|
app_->player()->RegisterUrlHandler(url_handler_);
|
||||||
app_->global_search()->AddProvider(
|
app_->global_search()->AddProvider(
|
||||||
new RadioBrowserSearchProvider(app_, this, this));
|
new RadioBrowserSearchProvider(app_, this, this));
|
||||||
}
|
}
|
||||||
|
@ -134,9 +138,8 @@ void RadioBrowserService::RefreshCategory(QStandardItem* item) {
|
||||||
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
||||||
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
||||||
|
|
||||||
NewClosure(reply, SIGNAL(finished()), this,
|
connect(reply, &QNetworkReply::finished,
|
||||||
SLOT(RefreshCategoryFinished(QNetworkReply*, int, QStandardItem*)),
|
[=] { this->RefreshCategoryFinished(reply, task_id, item); });
|
||||||
reply, task_id, item);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void RadioBrowserService::RefreshCategoryItem(QStandardItem* item) {
|
void RadioBrowserService::RefreshCategoryItem(QStandardItem* item) {
|
||||||
|
@ -149,9 +152,8 @@ void RadioBrowserService::RefreshCategoryItem(QStandardItem* item) {
|
||||||
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
||||||
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
||||||
|
|
||||||
NewClosure(reply, SIGNAL(finished()), this,
|
connect(reply, &QNetworkReply::finished,
|
||||||
SLOT(RefreshStreamsFinished(QNetworkReply*, int, QStandardItem*)),
|
[=] { this->RefreshStreamsFinished(reply, task_id, item); });
|
||||||
reply, task_id, item);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void RadioBrowserService::RefreshTop100(QStandardItem* item) {
|
void RadioBrowserService::RefreshTop100(QStandardItem* item) {
|
||||||
|
@ -163,9 +165,8 @@ void RadioBrowserService::RefreshTop100(QStandardItem* item) {
|
||||||
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
||||||
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
||||||
|
|
||||||
NewClosure(reply, SIGNAL(finished()), this,
|
connect(reply, &QNetworkReply::finished,
|
||||||
SLOT(RefreshStreamsFinished(QNetworkReply*, int, QStandardItem*)),
|
[=] { this->RefreshStreamsFinished(reply, task_id, item); });
|
||||||
reply, task_id, item);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void RadioBrowserService::ShowContextMenu(const QPoint& global_pos) {
|
void RadioBrowserService::ShowContextMenu(const QPoint& global_pos) {
|
||||||
|
@ -219,8 +220,8 @@ void RadioBrowserService::RefreshStreamsFinished(QNetworkReply* reply,
|
||||||
QJsonArray contents = document.array();
|
QJsonArray contents = document.array();
|
||||||
qLog(Debug) << "RadioBrowser station list found:" << contents.size();
|
qLog(Debug) << "RadioBrowser station list found:" << contents.size();
|
||||||
for (const QJsonValue& c : contents) {
|
for (const QJsonValue& c : contents) {
|
||||||
QJsonObject item = c.toObject();
|
QJsonObject station = c.toObject();
|
||||||
ReadStation(item, &list);
|
ReadStation(station, &list);
|
||||||
}
|
}
|
||||||
|
|
||||||
PopulateStreams(item, list);
|
PopulateStreams(item, list);
|
||||||
|
@ -229,8 +230,8 @@ void RadioBrowserService::RefreshStreamsFinished(QNetworkReply* reply,
|
||||||
void RadioBrowserService::ReadStation(QJsonObject& item, StreamList* ret) {
|
void RadioBrowserService::ReadStation(QJsonObject& item, StreamList* ret) {
|
||||||
Stream stream;
|
Stream stream;
|
||||||
stream.name_ = item["name"].toString();
|
stream.name_ = item["name"].toString();
|
||||||
stream.uuid_ = item["stationuuid"].toString();
|
QUrl url(item["stationuuid"].toString());
|
||||||
QUrl url(item["url"].toString());
|
url.setScheme(url_handler_->scheme());
|
||||||
stream.url_ = url;
|
stream.url_ = url;
|
||||||
QUrl favicon(item["favicon"].toString());
|
QUrl favicon(item["favicon"].toString());
|
||||||
stream.favicon_ = favicon;
|
stream.favicon_ = favicon;
|
||||||
|
@ -289,23 +290,11 @@ void RadioBrowserService::PopulateStreams(QStandardItem* parentItem,
|
||||||
InternetModel::Role_SongMetadata);
|
InternetModel::Role_SongMetadata);
|
||||||
item->setData(InternetModel::PlayBehaviour_SingleItem,
|
item->setData(InternetModel::PlayBehaviour_SingleItem,
|
||||||
InternetModel::Role_PlayBehaviour);
|
InternetModel::Role_PlayBehaviour);
|
||||||
item->setData(stream.uuid_, RadioBrowserService::Role_StationUuid);
|
|
||||||
|
|
||||||
parentItem->appendRow(item);
|
parentItem->appendRow(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QDataStream& operator<<(QDataStream& out,
|
|
||||||
const RadioBrowserService::Stream& stream) {
|
|
||||||
out << stream.name_ << stream.url_;
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
QDataStream& operator>>(QDataStream& in, RadioBrowserService::Stream& stream) {
|
|
||||||
in >> stream.name_ >> stream.url_;
|
|
||||||
return in;
|
|
||||||
}
|
|
||||||
|
|
||||||
void RadioBrowserService::ReloadSettings() {
|
void RadioBrowserService::ReloadSettings() {
|
||||||
QSettings s;
|
QSettings s;
|
||||||
s.beginGroup(kSettingsGroup);
|
s.beginGroup(kSettingsGroup);
|
||||||
|
@ -338,9 +327,8 @@ void RadioBrowserService::Search(int search_id, const QString& query,
|
||||||
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
||||||
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
int task_id = app_->task_manager()->StartTask(tr("Getting channels"));
|
||||||
|
|
||||||
NewClosure(reply, SIGNAL(finished()), this,
|
connect(reply, &QNetworkReply::finished,
|
||||||
SLOT(SearchFinishedInternal(QNetworkReply*, int, int)), reply,
|
[=] { this->SearchFinishedInternal(reply, task_id, search_id); });
|
||||||
task_id, search_id);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void RadioBrowserService::SearchFinishedInternal(QNetworkReply* reply,
|
void RadioBrowserService::SearchFinishedInternal(QNetworkReply* reply,
|
||||||
|
@ -360,17 +348,27 @@ void RadioBrowserService::SearchFinishedInternal(QNetworkReply* reply,
|
||||||
emit SearchFinished(search_id, list);
|
emit SearchFinished(search_id, list);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RadioBrowserService::ItemNowPlaying(QStandardItem* item) {
|
void RadioBrowserService::ResolveStationUrl(const QUrl& original_url) {
|
||||||
QString station_uuid =
|
QString determinedUrl = RadioBrowserService::PlayClickUrl.arg(
|
||||||
item->data(RadioBrowserService::Role_StationUuid).toString();
|
main_server_url_, original_url.path());
|
||||||
if (station_uuid.isEmpty()) return;
|
|
||||||
|
|
||||||
QString determinedUrl =
|
|
||||||
RadioBrowserService::PlayClickUrl.arg(main_server_url_, station_uuid);
|
|
||||||
QUrl url(determinedUrl);
|
QUrl url(determinedUrl);
|
||||||
|
|
||||||
qLog(Debug) << "RadioBrowser station played:" << determinedUrl;
|
|
||||||
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
QNetworkReply* reply = network_->get(QNetworkRequest(url));
|
||||||
connect(reply, &QNetworkReply::finished,
|
int task_id = app_->task_manager()->StartTask(tr("Getting station"));
|
||||||
[this, reply]() { reply->deleteLater(); });
|
|
||||||
}
|
connect(reply, &QNetworkReply::finished, [=] {
|
||||||
|
this->ResolveStationUrlFinished(reply, task_id, original_url);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
void RadioBrowserService::ResolveStationUrlFinished(QNetworkReply* reply,
|
||||||
|
int task_id,
|
||||||
|
const QUrl& original_url) {
|
||||||
|
app_->task_manager()->SetTaskFinished(task_id);
|
||||||
|
reply->deleteLater();
|
||||||
|
QJsonDocument document = ParseJsonReply(reply);
|
||||||
|
|
||||||
|
QJsonObject item = document.object();
|
||||||
|
QUrl url(item["url"].toString());
|
||||||
|
emit StationUrlResolved(original_url, url);
|
||||||
|
}
|
||||||
|
|
|
@ -50,13 +50,11 @@ class RadioBrowserService : public InternetService {
|
||||||
enum Role {
|
enum Role {
|
||||||
Role_ListUrl = InternetModel::RoleCount,
|
Role_ListUrl = InternetModel::RoleCount,
|
||||||
Role_ItemsUrl,
|
Role_ItemsUrl,
|
||||||
Role_StationUuid,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Stream {
|
struct Stream {
|
||||||
QString name_;
|
QString name_;
|
||||||
QUrl url_;
|
QUrl url_;
|
||||||
QString uuid_;
|
|
||||||
QUrl favicon_;
|
QUrl favicon_;
|
||||||
|
|
||||||
Song ToSong(const QString& prefix) const;
|
Song ToSong(const QString& prefix) const;
|
||||||
|
@ -77,8 +75,11 @@ class RadioBrowserService : public InternetService {
|
||||||
|
|
||||||
static const char* kServiceName;
|
static const char* kServiceName;
|
||||||
static const char* kSettingsGroup;
|
static const char* kSettingsGroup;
|
||||||
|
static const char* kSchemeName;
|
||||||
|
|
||||||
|
const QString& url_scheme() const { return url_scheme_; }
|
||||||
const QIcon& icon() const { return icon_; }
|
const QIcon& icon() const { return icon_; }
|
||||||
|
QNetworkAccessManager* network() const { return network_; }
|
||||||
|
|
||||||
QStandardItem* CreateRootItem();
|
QStandardItem* CreateRootItem();
|
||||||
void ShowContextMenu(const QPoint& global_pos);
|
void ShowContextMenu(const QPoint& global_pos);
|
||||||
|
@ -86,10 +87,11 @@ class RadioBrowserService : public InternetService {
|
||||||
PlaylistItem::Options playlistitem_options() const;
|
PlaylistItem::Options playlistitem_options() const;
|
||||||
|
|
||||||
void Search(int search_id, const QString& query, const int limit);
|
void Search(int search_id, const QString& query, const int limit);
|
||||||
void ItemNowPlaying(QStandardItem* item) override;
|
void ResolveStationUrl(const QUrl& original_url);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void SearchFinished(int search_id, RadioBrowserService::StreamList streams);
|
void SearchFinished(int search_id, RadioBrowserService::StreamList streams);
|
||||||
|
void StationUrlResolved(const QUrl& original_url, const QUrl& url);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void ReloadSettings();
|
void ReloadSettings();
|
||||||
|
@ -106,6 +108,8 @@ class RadioBrowserService : public InternetService {
|
||||||
QStandardItem* item);
|
QStandardItem* item);
|
||||||
void RefreshStreamsFinished(QNetworkReply* reply, int task_id,
|
void RefreshStreamsFinished(QNetworkReply* reply, int task_id,
|
||||||
QStandardItem* item);
|
QStandardItem* item);
|
||||||
|
void ResolveStationUrlFinished(QNetworkReply* reply, int task_id,
|
||||||
|
const QUrl& original_url);
|
||||||
void SearchFinishedInternal(QNetworkReply* reply, int task_id, int search_id);
|
void SearchFinishedInternal(QNetworkReply* reply, int task_id, int search_id);
|
||||||
|
|
||||||
void Homepage();
|
void Homepage();
|
||||||
|
@ -124,14 +128,11 @@ class RadioBrowserService : public InternetService {
|
||||||
QNetworkAccessManager* network_;
|
QNetworkAccessManager* network_;
|
||||||
|
|
||||||
const QString name_;
|
const QString name_;
|
||||||
|
const QString url_scheme_;
|
||||||
|
RadioBrowserUrlHandler* url_handler_;
|
||||||
QString main_server_url_;
|
QString main_server_url_;
|
||||||
const QUrl homepage_url_;
|
const QUrl homepage_url_;
|
||||||
const QIcon icon_;
|
const QIcon icon_;
|
||||||
};
|
};
|
||||||
|
|
||||||
QDataStream& operator<<(QDataStream& out,
|
|
||||||
const RadioBrowserService::Stream& stream);
|
|
||||||
QDataStream& operator>>(QDataStream& in, RadioBrowserService::Stream& stream);
|
|
||||||
Q_DECLARE_METATYPE(RadioBrowserService::Stream)
|
|
||||||
|
|
||||||
#endif // INTERNET_RADIOBROWSER_RADIOBROWSERSERVICE_H_
|
#endif // INTERNET_RADIOBROWSER_RADIOBROWSERSERVICE_H_
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
/* This file is part of Clementine.
|
||||||
|
Copyright 2021, Fabio Bas <ctrlaltca@gmail.com>
|
||||||
|
|
||||||
|
Clementine 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.
|
||||||
|
|
||||||
|
Clementine 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 Clementine. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "radiobrowserurlhandler.h"
|
||||||
|
|
||||||
|
#include <QNetworkAccessManager>
|
||||||
|
#include <QNetworkReply>
|
||||||
|
|
||||||
|
#include "core/application.h"
|
||||||
|
#include "core/taskmanager.h"
|
||||||
|
#include "radiobrowserservice.h"
|
||||||
|
|
||||||
|
RadioBrowserUrlHandler::RadioBrowserUrlHandler(Application* app,
|
||||||
|
RadioBrowserService* service,
|
||||||
|
QObject* parent)
|
||||||
|
: UrlHandler(parent), app_(app), service_(service) {
|
||||||
|
connect(service_, &RadioBrowserService::StationUrlResolved, this,
|
||||||
|
&RadioBrowserUrlHandler::LoadStationFinished);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString RadioBrowserUrlHandler::scheme() const {
|
||||||
|
return RadioBrowserService::kSchemeName;
|
||||||
|
}
|
||||||
|
|
||||||
|
QIcon RadioBrowserUrlHandler::icon() const { return service_->icon(); }
|
||||||
|
|
||||||
|
UrlHandler::LoadResult RadioBrowserUrlHandler::StartLoading(const QUrl& url) {
|
||||||
|
service_->ResolveStationUrl(url);
|
||||||
|
return LoadResult(url, LoadResult::WillLoadAsynchronously);
|
||||||
|
}
|
||||||
|
|
||||||
|
void RadioBrowserUrlHandler::LoadStationFinished(const QUrl& original_url,
|
||||||
|
const QUrl& url) {
|
||||||
|
if (url.isValid()) {
|
||||||
|
emit AsyncLoadComplete(
|
||||||
|
LoadResult(original_url, LoadResult::TrackAvailable, url));
|
||||||
|
} else {
|
||||||
|
qLog(Error) << "Error loading" << original_url;
|
||||||
|
emit AsyncLoadComplete(LoadResult(original_url, LoadResult::NoMoreTracks));
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
/* This file is part of Clementine.
|
||||||
|
Copyright 2021, Fabio Bas <ctrlaltca@gmail.com>
|
||||||
|
|
||||||
|
Clementine 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.
|
||||||
|
|
||||||
|
Clementine 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 Clementine. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef INTERNET_RADIOBROWSER_RADIOBROWSERURLHANDLER_H_
|
||||||
|
#define INTERNET_RADIOBROWSER_RADIOBROWSERURLHANDLER_H_
|
||||||
|
|
||||||
|
#include "core/urlhandler.h"
|
||||||
|
#include "ui/iconloader.h"
|
||||||
|
|
||||||
|
class RadioBrowserService;
|
||||||
|
class Application;
|
||||||
|
|
||||||
|
// RadioBrowser URL handler: radiobrowser://uuid
|
||||||
|
class RadioBrowserUrlHandler : public UrlHandler {
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
RadioBrowserUrlHandler(Application* app, RadioBrowserService* service,
|
||||||
|
QObject* parent);
|
||||||
|
|
||||||
|
QString scheme() const;
|
||||||
|
QIcon icon() const;
|
||||||
|
LoadResult StartLoading(const QUrl& url);
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void LoadStationFinished(const QUrl& original_url, const QUrl& url);
|
||||||
|
|
||||||
|
private:
|
||||||
|
Application* app_;
|
||||||
|
RadioBrowserService* service_;
|
||||||
|
int task_id_;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // INTERNET_RADIOBROWSER_RADIOBROWSERURLHANDLER_H_
|
Loading…
Reference in New Issue