1
0
Fork 0
mirror of https://github.com/HenkKalkwater/harbour-sailfin.git synced 2024-09-28 18:08:22 +00:00
harbour-sailfin/core/src/loader/http/mediainfo.cpp

205 lines
8 KiB
C++
Raw Normal View History

/*
* Sailfin: a Jellyfin client written using Qt
* Copyright (C) 2021 Chris Josten and the Sailfin Contributors.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
/*
* WARNING: THIS IS AN AUTOMATICALLY GENERATED FILE! PLEASE DO NOT EDIT THIS, AS YOUR EDITS WILL GET
* OVERWRITTEN AT SOME POINT!
*
* If there is a bug in this file, please fix the code generator used to generate this file found in
* core/openapigenerator.d.
*
* This file is generated based on Jellyfin's OpenAPI description, "openapi.json". Please update that
* file with a newer file if needed instead of manually updating the files.
*/
#include <JellyfinQt/loader/http/mediainfo.h>
namespace Jellyfin {
namespace Loader {
namespace HTTP {
using namespace Jellyfin::DTO;
GetPlaybackInfoLoader::GetPlaybackInfoLoader(ApiClient *apiClient)
: Jellyfin::Support::HttpLoader<PlaybackInfoResponse, GetPlaybackInfoParams>(apiClient) {}
QString GetPlaybackInfoLoader::path(const GetPlaybackInfoParams &params) const {
Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
return QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/PlaybackInfo");
}
QUrlQuery GetPlaybackInfoLoader::query(const GetPlaybackInfoParams &params) const {
Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
QUrlQuery result;
result.addQueryItem("userId", Support::toString<QString>(params.userId()));
// Optional parameters
return result;
}
QByteArray GetPlaybackInfoLoader::body(const GetPlaybackInfoParams &params) const {
return QByteArray();
}
QNetworkAccessManager::Operation GetPlaybackInfoLoader::operation() const {
// HTTP method Get
return QNetworkAccessManager::GetOperation;
}
2021-03-26 20:27:35 +00:00
GetPostedPlaybackInfoLoader::GetPostedPlaybackInfoLoader(ApiClient *apiClient)
: Jellyfin::Support::HttpLoader<PlaybackInfoResponse, GetPostedPlaybackInfoParams>(apiClient) {}
2021-03-26 20:27:35 +00:00
QString GetPostedPlaybackInfoLoader::path(const GetPostedPlaybackInfoParams &params) const {
Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
return QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/PlaybackInfo");
}
2021-03-26 20:27:35 +00:00
QUrlQuery GetPostedPlaybackInfoLoader::query(const GetPostedPlaybackInfoParams &params) const {
Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
QUrlQuery result;
// Optional parameters
if (!params.userIdNull()) {
result.addQueryItem("userId", Support::toString<QString>(params.userId()));
}
if (!params.maxStreamingBitrateNull()) {
result.addQueryItem("maxStreamingBitrate", Support::toString<std::optional<qint32>>(params.maxStreamingBitrate()));
}
if (!params.startTimeTicksNull()) {
result.addQueryItem("startTimeTicks", Support::toString<std::optional<qint64>>(params.startTimeTicks()));
}
if (!params.audioStreamIndexNull()) {
result.addQueryItem("audioStreamIndex", Support::toString<std::optional<qint32>>(params.audioStreamIndex()));
}
if (!params.subtitleStreamIndexNull()) {
result.addQueryItem("subtitleStreamIndex", Support::toString<std::optional<qint32>>(params.subtitleStreamIndex()));
}
if (!params.maxAudioChannelsNull()) {
result.addQueryItem("maxAudioChannels", Support::toString<std::optional<qint32>>(params.maxAudioChannels()));
}
if (!params.mediaSourceIdNull()) {
result.addQueryItem("mediaSourceId", Support::toString<QString>(params.mediaSourceId()));
}
if (!params.liveStreamIdNull()) {
result.addQueryItem("liveStreamId", Support::toString<QString>(params.liveStreamId()));
}
if (!params.autoOpenLiveStreamNull()) {
result.addQueryItem("autoOpenLiveStream", Support::toString<std::optional<bool>>(params.autoOpenLiveStream()));
}
if (!params.enableDirectPlayNull()) {
result.addQueryItem("enableDirectPlay", Support::toString<std::optional<bool>>(params.enableDirectPlay()));
}
if (!params.enableDirectStreamNull()) {
result.addQueryItem("enableDirectStream", Support::toString<std::optional<bool>>(params.enableDirectStream()));
}
if (!params.enableTranscodingNull()) {
result.addQueryItem("enableTranscoding", Support::toString<std::optional<bool>>(params.enableTranscoding()));
}
if (!params.allowVideoStreamCopyNull()) {
result.addQueryItem("allowVideoStreamCopy", Support::toString<std::optional<bool>>(params.allowVideoStreamCopy()));
}
if (!params.allowAudioStreamCopyNull()) {
result.addQueryItem("allowAudioStreamCopy", Support::toString<std::optional<bool>>(params.allowAudioStreamCopy()));
}
return result;
}
QByteArray GetPostedPlaybackInfoLoader::body(const GetPostedPlaybackInfoParams &params) const {
return Support::toString<QSharedPointer<PlaybackInfoDto>>(params.body()).toUtf8();
}
QNetworkAccessManager::Operation GetPostedPlaybackInfoLoader::operation() const {
// HTTP method Post
return QNetworkAccessManager::PostOperation;
}
OpenLiveStreamLoader::OpenLiveStreamLoader(ApiClient *apiClient)
: Jellyfin::Support::HttpLoader<LiveStreamResponse, OpenLiveStreamParams>(apiClient) {}
QString OpenLiveStreamLoader::path(const OpenLiveStreamParams &params) const {
Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
return QStringLiteral("/LiveStreams/Open");
}
QUrlQuery OpenLiveStreamLoader::query(const OpenLiveStreamParams &params) const {
Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
QUrlQuery result;
// Optional parameters
if (!params.openTokenNull()) {
result.addQueryItem("openToken", Support::toString<QString>(params.openToken()));
}
if (!params.userIdNull()) {
result.addQueryItem("userId", Support::toString<QString>(params.userId()));
}
if (!params.playSessionIdNull()) {
result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
}
if (!params.maxStreamingBitrateNull()) {
result.addQueryItem("maxStreamingBitrate", Support::toString<std::optional<qint32>>(params.maxStreamingBitrate()));
}
if (!params.startTimeTicksNull()) {
result.addQueryItem("startTimeTicks", Support::toString<std::optional<qint64>>(params.startTimeTicks()));
}
if (!params.audioStreamIndexNull()) {
result.addQueryItem("audioStreamIndex", Support::toString<std::optional<qint32>>(params.audioStreamIndex()));
}
if (!params.subtitleStreamIndexNull()) {
result.addQueryItem("subtitleStreamIndex", Support::toString<std::optional<qint32>>(params.subtitleStreamIndex()));
}
if (!params.maxAudioChannelsNull()) {
result.addQueryItem("maxAudioChannels", Support::toString<std::optional<qint32>>(params.maxAudioChannels()));
}
if (!params.itemIdNull()) {
result.addQueryItem("itemId", Support::toString<QString>(params.itemId()));
}
if (!params.enableDirectPlayNull()) {
result.addQueryItem("enableDirectPlay", Support::toString<std::optional<bool>>(params.enableDirectPlay()));
}
if (!params.enableDirectStreamNull()) {
result.addQueryItem("enableDirectStream", Support::toString<std::optional<bool>>(params.enableDirectStream()));
}
return result;
}
QByteArray OpenLiveStreamLoader::body(const OpenLiveStreamParams &params) const {
return Support::toString<QSharedPointer<OpenLiveStreamDto>>(params.body()).toUtf8();
}
QNetworkAccessManager::Operation OpenLiveStreamLoader::operation() const {
// HTTP method Post
return QNetworkAccessManager::PostOperation;
}
} // NS HTTP
} // NS Loader
} // NS Jellyfin