1
0
Fork 0
mirror of https://github.com/HenkKalkwater/harbour-sailfin.git synced 2025-09-01 08:52:45 +00:00
harbour-sailfin/core/include/JellyfinQt/loader/http/image.h
Henk Kalkwater 9e1a20cd3a [2/3] update openapi spec: generate code
This updates the openapi spec and invokes the code generator to update
to the Jellyfin 10.10.6 API.

A big motivation to do this was because some mandatory fields have been
made obsolete and are no longer included in responses. Sailfin tries to
deserialize these mandatory fields and fails deserializing. It was evident
in the list of sessions to control.

The failing was a bit too gracefully in my opinion, it did not even show
that an error occurred, nor was it logged anywhere. It took some time
to debug.
2025-03-19 22:06:54 +01:00

196 lines
7 KiB
C++

/*
* 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.
*/
#ifndef JELLYFIN_LOADER_HTTP_IMAGE_H
#define JELLYFIN_LOADER_HTTP_IMAGE_H
#include <optional>
#include "JellyfinQt/support/jsonconv.h"
#include "JellyfinQt/support/loader.h"
#include "JellyfinQt/loader/requesttypes.h"
#include "JellyfinQt/dto/imageinfo.h"
namespace Jellyfin {
// Forward declaration
class ApiClient;
}
namespace Jellyfin {
namespace Loader {
namespace HTTP {
using namespace Jellyfin::DTO;
/**
* @brief Uploads a custom splashscreen.
The body is expected to the image contents base64 encoded.
*/
class UploadCustomSplashscreenLoader : public Jellyfin::Support::HttpLoader<void, UploadCustomSplashscreenParams> {
public:
explicit UploadCustomSplashscreenLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const UploadCustomSplashscreenParams& parameters) const override;
QUrlQuery query(const UploadCustomSplashscreenParams& parameters) const override;
QByteArray body(const UploadCustomSplashscreenParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Delete a custom splashscreen.
*/
class DeleteCustomSplashscreenLoader : public Jellyfin::Support::HttpLoader<void, DeleteCustomSplashscreenParams> {
public:
explicit DeleteCustomSplashscreenLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const DeleteCustomSplashscreenParams& parameters) const override;
QUrlQuery query(const DeleteCustomSplashscreenParams& parameters) const override;
QByteArray body(const DeleteCustomSplashscreenParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Get item image infos.
*/
class GetItemImageInfosLoader : public Jellyfin::Support::HttpLoader<QList<ImageInfo>, GetItemImageInfosParams> {
public:
explicit GetItemImageInfosLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const GetItemImageInfosParams& parameters) const override;
QUrlQuery query(const GetItemImageInfosParams& parameters) const override;
QByteArray body(const GetItemImageInfosParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Delete an item's image.
*/
class DeleteItemImageLoader : public Jellyfin::Support::HttpLoader<void, DeleteItemImageParams> {
public:
explicit DeleteItemImageLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const DeleteItemImageParams& parameters) const override;
QUrlQuery query(const DeleteItemImageParams& parameters) const override;
QByteArray body(const DeleteItemImageParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Set item image.
*/
class SetItemImageLoader : public Jellyfin::Support::HttpLoader<void, SetItemImageParams> {
public:
explicit SetItemImageLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const SetItemImageParams& parameters) const override;
QUrlQuery query(const SetItemImageParams& parameters) const override;
QByteArray body(const SetItemImageParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Delete an item's image.
*/
class DeleteItemImageByIndexLoader : public Jellyfin::Support::HttpLoader<void, DeleteItemImageByIndexParams> {
public:
explicit DeleteItemImageByIndexLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const DeleteItemImageByIndexParams& parameters) const override;
QUrlQuery query(const DeleteItemImageByIndexParams& parameters) const override;
QByteArray body(const DeleteItemImageByIndexParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Set item image.
*/
class SetItemImageByIndexLoader : public Jellyfin::Support::HttpLoader<void, SetItemImageByIndexParams> {
public:
explicit SetItemImageByIndexLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const SetItemImageByIndexParams& parameters) const override;
QUrlQuery query(const SetItemImageByIndexParams& parameters) const override;
QByteArray body(const SetItemImageByIndexParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Updates the index for an item image.
*/
class UpdateItemImageIndexLoader : public Jellyfin::Support::HttpLoader<void, UpdateItemImageIndexParams> {
public:
explicit UpdateItemImageIndexLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const UpdateItemImageIndexParams& parameters) const override;
QUrlQuery query(const UpdateItemImageIndexParams& parameters) const override;
QByteArray body(const UpdateItemImageIndexParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Sets the user image.
*/
class PostUserImageLoader : public Jellyfin::Support::HttpLoader<void, PostUserImageParams> {
public:
explicit PostUserImageLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const PostUserImageParams& parameters) const override;
QUrlQuery query(const PostUserImageParams& parameters) const override;
QByteArray body(const PostUserImageParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
/**
* @brief Delete the user's image.
*/
class DeleteUserImageLoader : public Jellyfin::Support::HttpLoader<void, DeleteUserImageParams> {
public:
explicit DeleteUserImageLoader(ApiClient *apiClient = nullptr);
protected:
QString path(const DeleteUserImageParams& parameters) const override;
QUrlQuery query(const DeleteUserImageParams& parameters) const override;
QByteArray body(const DeleteUserImageParams& parameters) const override;
QNetworkAccessManager::Operation operation() const override;
};
} // NS HTTP
} // NS Loader
} // NS Jellyfin
#endif // JELLYFIN_LOADER_HTTP_IMAGE_H